使用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. 两个div在同一行,两个div不换行

    方法一: <div style="display:inline"> <div id="div1" style="float:left ...

  2. MVC的DependencyResolver组件

    MVC的DependencyResolver组件 一.前言 DependencyResolver是MVC中一个重要的组件,从名字可以看出,它负责依赖对象的解析,可以说它是MVC框架内部使用的一个IOC ...

  3. 面试题 收集请求k千里马

    收集请求k最大值 个人信息:就读于燕大本科软件project专业 眼下大三; 本人博客:google搜索"cqs_2012"就可以; 个人爱好:酷爱数据结构和算法,希望将来从事算法 ...

  4. BDB (Berkeley DB)简要数据库(转载)

    使用最近DBD.然后搜了下相关资料,首先公布的是一门科学: 转会http://www.javaeye.com/topic/202990 DB综述DB最初开发的目的是以新的HASH訪问算法来取代旧的hs ...

  5. Easy 2048 Again - ZOJ 3802 像缩进dp

    Easy 2048 Again Time Limit: 2 Seconds      Memory Limit: 65536 KB Dark_sun knows that on a single-tr ...

  6. 802.11(wifi)的MAC层功能

    MAC层是802.11的主要功能部分.上层应用通过调用MAC层提供的接口原语调用MAC层的功能. MAC一共向上提供了2大类接口原语,共30种.数据(1)和管理(29).数据部分就是提供普通数据包的收 ...

  7. Android自带样式

    Android系统自带样式: android:theme="@android:style/Theme.Dialog" 将一个Activity显示为对话框模式 android:the ...

  8. 每天努力一点之SQL(二) count sum case when then group by

    1. select sum(CASE WHEN A.[STATUS]=0 THEN 1 ELSE 0 end) as a1,  sum(CASE A.[STATUS] WHEN 1 THEN 1 EL ...

  9. C++习题 商品销售

    Description 商店销售某一商品,每天公布统一的折扣(discount).同时允许销售人员在销售时灵活掌握售价(price),在此基础上,一次购10件以上者,还可以享受9.8折优惠.现已知当天 ...

  10. 深入解析_Android的自定义布局

    前言: 这篇文章是前Firefox Android工程师(现在跳槽去Facebook了) Lucas Rocha所写,文中对Android中常用的四种自定义布局方案进行了很好地分析,并结合这四种And ...