使用java它们的定义jar套餐读excel数据支持excel2007和excel2003

在http://download.csdn.net/detail/u010792467/8079355下载所须要的包

假设须要excel2003和excel2007文件能够去

http://download.csdn.net/detail/u010792467/8072009下载

在http://download.csdn.net/detail/u010792467/8079345下载project

自己定义jar包运用举例

<span style="font-size:18px;">package com.readExcel;

import java.util.List;

import Excel.ImportExeclTool;

public class exceltest {
public static void main(String[] args) {
// String filePath = "D:\\excel\\EXCEL2007測试.xlsx";
String filePath="D:\\excel\\EXCEL2003測试.xls";
ImportExeclTool impexcel = new ImportExeclTool();
// 所有sheet页内容
// List<List<String>> list= impexcel.readExcel(filePath);
// filePath excel文件路径
// 1 代表第一个sheet页 2 代表第一个sheet页...
List<List<String>> list = impexcel.readExcel(filePath, 1);
if (list != null) { for (int i = 0; i < list.size(); i++) { System.out.print("第" + (i) + "行"); List<String> listCell = list.get(i); for (String s : listCell) {
System.out.print(" " + s);
}
System.out.println(); } }
System.out.println("执行完毕");
}
}
</span>

自己定义jar包源代码

<span style="font-size:18px;">package Excel;

import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.List; import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.usermodel.Workbook;
import org.apache.poi.xssf.usermodel.XSSFWorkbook; public class ImportExeclTool {
private String errorInfo;
private static int readSheet = 0;
private static boolean readSheetNum = false;
private static boolean isGtSheetNum = false; public boolean validateExcel(String filePath) { if (filePath == null
|| !(is2003Excel(filePath) || is2007Excel(filePath))) { errorInfo = "文件名称不是excel格式"; return false;
} File file = new File(filePath); if (file == null || !file.exists()) { errorInfo = "excel文件不存在"; return false; } return true; } public List<List<String>> readExcel(String filePath) { List<List<String>> dataList = new ArrayList<List<String>>(); InputStream is = null; try { if (!validateExcel(filePath)) { System.out.println();
List<String> list3 = new ArrayList<String>();
list3.add(errorInfo);
dataList.add(list3);
return dataList; } boolean is2003Excel = true; if (is2007Excel(filePath)) { is2003Excel = false;
} File file = new File(filePath); is = new FileInputStream(file); dataList = readFile(is, is2003Excel); is.close(); } catch (Exception ex) { ex.printStackTrace(); } finally { if (is != null) { try { is.close(); } catch (IOException e) { is = null; e.printStackTrace(); } } } return dataList; } public List<List<String>> readFile(InputStream inputStream,
boolean is2003Excel) { List<List<String>> dataLists = null; try { Workbook wb = null; if (is2003Excel) {
wb = new HSSFWorkbook(inputStream);
} else {
wb = new XSSFWorkbook(inputStream);
}
int sheetNum = sheetCirculation(wb);
if (readSheet >= sheetNum) {
List<String> list2 = new ArrayList<String>();
list2.add("输入页数大于实际sheet页数!!!");
List list4 = new ArrayList();
list4.add(list2);
this.isGtSheetNum = true;
return list4;
}
List<List<String>> dataList = new ArrayList<List<String>>();
if (readSheetNum) {
dataLists = read(dataList, wb, readSheet);
} else {
for (int i = 0; i < sheetNum; i++) {
dataLists = read(dataList, wb, i);
}
} } catch (IOException e) { e.printStackTrace(); } return dataLists; } private List<List<String>> read(List<List<String>> dataList, Workbook wb,
int sheets) {
int totalRows = 0;
int totalCells = 0; Sheet sheet = wb.getSheetAt(sheets); totalRows = sheet.getPhysicalNumberOfRows(); if (totalRows >= 1 && sheet.getRow(0) != null) { totalCells = sheet.getRow(0).getPhysicalNumberOfCells(); }
for (int r = 0; r < totalRows; r++) { Row row = sheet.getRow(r); if (row == null) { continue; } List<String> rowDataList = new ArrayList<String>(); for (int c = 0; c < totalCells; c++) { Cell cell = row.getCell(c); String cellValue = ""; if (null != cell) {
switch (cell.getCellType()) {
case HSSFCell.CELL_TYPE_NUMERIC: // 数字
cellValue = cell.getNumericCellValue() + "";
break; case HSSFCell.CELL_TYPE_STRING: // 字符串
cellValue = cell.getStringCellValue();
break; case HSSFCell.CELL_TYPE_BOOLEAN: // Boolean
cellValue = cell.getBooleanCellValue() + "";
break; case HSSFCell.CELL_TYPE_FORMULA: // 公式
cellValue = cell.getCellFormula() + "";
break; case HSSFCell.CELL_TYPE_BLANK: // 空值
cellValue = "";
break; case HSSFCell.CELL_TYPE_ERROR: // 故障
cellValue = "非法字符";
break; default:
cellValue = "未知类型";
break;
}
} rowDataList.add(cellValue); }
dataList.add(rowDataList); }
return dataList; } private int sheetCirculation(Workbook wb) {
int sheetCount = -1;
sheetCount = wb.getNumberOfSheets();
return sheetCount;
} public static boolean is2003Excel(String filePath) { return filePath.matches("^.+\\.(? i)(xls)$"); } public static boolean is2007Excel(String filePath) { return filePath.matches("^.+\\.(?i)(xlsx)$"); } public ImportExeclTool() {
} public String getErrorInfo() {
return errorInfo;
} public List<List<String>> readExcel(String filePath, int num) {
this.readSheet = num - 1;
this.readSheetNum = true;
if (num <= 0) {
List list0 = new ArrayList();
List list5 = new ArrayList();
list0.add("excel必须大于0页!!!");
list5.add(list0);
return list5;
}
List<List<String>> list = readExcel(filePath);
if (!this.isGtSheetNum && list.size() == 0) {
List<String> list1 = new ArrayList<String>();
list1.add("sheet页中数据为空!!!");
list.add(list1);
}
return list;
}
}
</span>

作者:儱剑阿攵

转载请注明链接:http://blog.csdn.net/awenluck/article/details/40442207

版权声明:本文博客原创文章,博客,未经同意,不得转载。

java它们的定义jar套餐读Excel(这包括2003和2007)数据,和实例的更多相关文章

  1. java利用Aspose.cells.jar将本地excel文档转化成pdf(完美破解版 无水印 无中文乱码)

    下载aspose-cells-8.5.2.jar包 http://pan.baidu.com/s/1kUBzsQ7 JAVA代码 package webViewer; import java.io.* ...

  2. Java 使用poi导入excel,结合xml文件进行数据验证的例子(增加了jar包)

    ava 使用poi导入excel,结合xml文件进行数据验证的例子(增加了jar包) 假设现在要做一个通用的导入方法: 要求: 1.xml的只定义数据库表中的column字段,字段类型,是否非空等条件 ...

  3. Java中使用jxl.jar将数据导出为excel文件

      Java对Excel文件的读写操作可由jxl.jar或poi.jar实现,这里使用jxl.jar完成对Excel文件的导出. 一.将Excel文件导出在本地 步骤:   创建文件 -> 创建 ...

  4. Java中使用poi导入、导出Excel

    一.介绍 当前B/S模式已成为应用开发的主流,而在企业办公系统中,常常有客户这样子要求:你要把我们的报表直接用Excel打开(电信系统.银行系统).或者是:我们已经习惯用Excel打印.这样在我们实际 ...

  5. 用java从0生成一个简单的excel

    用java从0生成一个简单的excel 目标 用代码实现对一个excel的基础操作,包括创建,插入文字,(好像就这些了),生成的excel可以用wps打开,如果直接用c++的文件流会生成假的xls表格 ...

  6. java用org.apache.poi包操作excel

    一.POI简介 Jakarta POI 是apache的子项目,目标是处理ole2对象.它提供了一组操纵Windows文档的Java API 目前比较成熟的是HSSF接口,处理MS Excel(97- ...

  7. Excel文件按照指定模板导入数据(用jxl.jar包)

        本文中的方法只适合Excel2003,要读取Excel2007最好使用poi.jar,据说poi.jar还在更新,jxl.jar已经不更新了,处理Excel文件的读写问题最好还是学习poi.j ...

  8. java中最常用jar包的用途说明

    java中最常用jar包的用途说明,适合初学者 jar包 用途 axis.jar SOAP引擎包 commons-discovery-0.2.jar 用来发现.查找和实现可插入式接口,提供一些一般类实 ...

  9. c#读excel 不用office组件

    某日笔者写了个导入导出excel的小程序,拿给别人用时,别人说程序有问题读不了. 究其原因发现原来是using Microsoft.Office.Interop.Excel;引用出错.发现他装的off ...

随机推荐

  1. Android数据库高手秘籍(五)——LitePal的存储操作

    转载请注明出处:http://blog.csdn.net/guolin_blog/article/details/39345833 经过前面几篇文章的学习,我们已经把LitePal的表管理模块的功能都 ...

  2. Visual Studio Code中配置GO开发环境

    在Visual Studio Code中配置GO开发环境 一.GO语言安装 详情查看:GO语言下载.安装.配置 二.GoLang插件介绍 对于Visual Studio Code开发工具,有一款优秀的 ...

  3. .NET 使用 MySql.Data.dll 动态库操作MySql的帮助类--MySqlHelper

    .NET 使用 MySql.Data.dll 动态库操作MySql的帮助类--MySqlHelper 參考演示样例代码,例如以下所看到的: /// <summary> /// MySql ...

  4. Windows Phone开发(11):常用控件(下)

    原文:Windows Phone开发(11):常用控件(下) WP控件大部分都可以从Silverlight中继承过来,这里我也只能拿一部分作演示,对于其它控件如何使用,可以参考SDK相关说明以及Sil ...

  5. Composite Design Pattern 设计模式组合

    设计模式组合,它能够更类组合在一类,形成一个树状结构. #include <set> #include <iostream> #include <string> u ...

  6. Oracle SQL Lesson (8) - 使用集合操作符(Union,Intersect,Minus)

    集合操作符UNION/UNION ALLINTERSECTMINUS Union All不排序,不去重,其余均升序且去重.create table e1 as select * from emp wh ...

  7. C# 视频教程

    http://www.cnblogs.com/kellen/tag/Silverlight/ http://www.lanmaodream.com/archives/244.html

  8. Windows Server 2012 R2在桌面上显示计算机/网络图标

    原文 Windows Server 2012 R2在桌面上显示计算机/网络图标 从Windows2012开始,微软取消了服务器桌面个性化选项,如何重新调出配置界面,可以使用微软命令调出.具体方法如下: ...

  9. mapreduce程序来实现分类

    文件的内容例如以下所看到的: 5 45 8 876 6 45 要求最后的输出格式: 1    5 2    6 3    8 4    45 5    45 5    876 首先,这个题目是须要对文 ...

  10. JAVA IP地址转成长整型方法

    JAVA IP地址转成长整型方法 代码例如以下: /** * IP转成整型 * @param ip * @return */ public static Long ip2int(String ip) ...