HSSFWorkbook:是操作Excel2003以前(包括2003)的版本,扩展名是.xls;
XSSFWorkbook:是操作Excel2007的版本,扩展名是.xlsx;

1.注意点

                    getPhysicalNumberOfRows()获取的是物理行数,也就是不包括那些空行(隔行)的情况(编号从1开始)。
getLastRowNum()获取的是最后一行的编号(编号从0开始)。
getPhysicalNumberOfCells 是获取不为空的列个数。
getLastCellNum 是获取最后一个不为空的列是第几个。 eg.
我使用getLastRowNum()获取行数,getLastCellNum获取列数:
Excel中 有12行,11列。

int rows = sheet.getLastRowNum(); //获取的是最后一行的编号(编号从0开始)
  System.out.println("rows=="+rows);    //rows==11
  int cells = sheet.getRow(startrow).getLastCellNum();
  System.out.println("cells=="+cells);  //cells==11

------------------------------------------------------------------------------------------------------

CELL_TYPE_NUMERIC 数值型 0
CELL_TYPE_STRING 字符串型 1
CELL_TYPE_FORMULA 公式型 2
CELL_TYPE_BLANK 空值 3
CELL_TYPE_BOOLEAN 布尔型 4
CELL_TYPE_ERROR 错误 5


2.HSSFWorkbook的关键代码

   /**
* 读取后缀名为xls的Excel
*/
public static List<Map<String,String>> readExcel2003(String filename) throws FileNotFoundException, IOException{
int startrow = 0; //第一行开始读取 List<String> columnNameList = new ArrayList<String>();
List<Map<String,String>> list = new ArrayList<Map<String,String>>(); HSSFWorkbook wookbook = new HSSFWorkbook(new FileInputStream(new File(filename)));
HSSFSheet sheet = wookbook.getSheetAt(0);
int rows = sheet.getLastRowNum(); //获取的是最后一行的编号(编号从0开始)
System.out.println("rows=="+rows);
int cells = sheet.getRow(startrow).getLastCellNum();
System.out.println("cells=="+cells);
for (int i=0; i < (rows+1); i++) { //获取的是最后一行的编号(编号从0开始)。所以rows+1
HSSFRow row = sheet.getRow(i);
if (row != null) {
if (i==startrow) { //获取名称
for (int j=0; j<cells; j++) {
HSSFCell cell = row.getCell(j);
if (cell != null && !cell.getStringCellValue().equals("")) {
columnNameList.add(cell.getStringCellValue());
System.out.println(j + ":" + cell.getStringCellValue());
}else {
cells=j; //cells为size所以从1开始
break;
}
}
}
else {
Map<String, String> map = new HashMap<String, String>();
for (int j = 0; j < cells; j++) {
HSSFCell cell = row.getCell(j);
if (cell != null) {
map.put(columnNameList.get(j), cell.getStringCellValue());
}else{
map.put(columnNameList.get(j), null);
}
}
list.add(map);
}
}
}
return list;
}

3.XSSFWorkbook的关键代码

       /**
* 读取后缀名为xlsx的Excel
*/
public static List<Map<String,String>> readExcel2007(String filename) throws FileNotFoundException, IOException{
int startrow = 0; //第一行开始读取 List<String> columnNameList = new ArrayList<String>();
List<Map<String,String>> list = new ArrayList<Map<String,String>>(); XSSFWorkbook workbook = new XSSFWorkbook(new FileInputStream(new File(filename)));
XSSFSheet sheet = workbook.getSheetAt(0);
int rows = sheet.getLastRowNum();
// System.out.println("rows:"+ rows);
int cells = sheet.getRow(startrow).getLastCellNum();
for (int i=0; i < (rows+1); i++) { //获取的是最后一行的编号(编号从0开始)。所以rows+1
XSSFRow row = sheet.getRow(i);
if (row != null) {
if(i == startrow) { //获取名称
for (int j=0; j<cells; j++) {
XSSFCell cell = row.getCell(j);
if (cell != null && !cell.getStringCellValue().equals("")) {
columnNameList.add(cell.getStringCellValue());
}else {
cells=j; //cells为size所以从1开始
break;
}
}
}else {
Map<String, String> map = new HashMap<String, String>();
for (int j = 0; j < cells; j++) {
XSSFCell cell = row.getCell(j);
if (cell != null) {
switch (cell.getCellType()) {
case HSSFCell.CELL_TYPE_FORMULA:
case HSSFCell.CELL_TYPE_NUMERIC:
boolean flag = HSSFDateUtil.isCellDateFormatted(cell);
if(flag){
SimpleDateFormat sdf = new SimpleDateFormat("yyyy/MM/dd");
Date date = cell.getDateCellValue();
String result = sdf.format(date);
map.put(columnNameList.get(j), result);
}else{
String str = String.valueOf(cell.getNumericCellValue());
str = str.substring(0, str.length()-2);
map.put(columnNameList.get(j), str);
}
break;
case HSSFCell.CELL_TYPE_STRING:
map.put(columnNameList.get(j), cell.getStringCellValue());
break;
default:
map.put(columnNameList.get(j), null);
break;
}
}else {
map.put(columnNameList.get(j), null);
}
}
list.add(map);
}
}
}
return list;
}

4.相关jar下载

java读取excel所需jar包

最新文章

  1. 获取ICommand的图片
  2. C语言实现GPT头和分区表的读取(gcc)
  3. 2009年到2013年甲子园ED
  4. C++(MFC)中WebBrowser去除3D边框的方法(实现IDocHostUIHandler接口)控制 WebBrowser 控件的外观和行为
  5. sql server对并发的处理-乐观锁和悲观锁【粘】
  6. Protected Member Access
  7. ANDROID对文件的操作介绍
  8. 【cocos2d-js公文】十七、事件分发机制
  9. sql编程 &amp;&amp; 存储过程
  10. Goods transportation
  11. [更新]单线程的JS引擎与 Event Loop
  12. springcloud情操陶冶-springcloud config server(二)
  13. 在CentOS6的上安装Windows2012R2的KVM虚拟机
  14. redis 4 集群重启与数据导入
  15. dubbo启动报错failed to bind nettyserver on
  16. Java中的Future模式原理自定义实现
  17. 【loj2461】【2018集训队互测Day 1】完美的队列
  18. Julia - 分数
  19. LOJ #6278. 数列分块入门 2-分块(区间加法、查询区间内小于某个值x的元素个数)
  20. 软件测试工程师的Linux之路(持续更新修正)

热门文章

  1. 定义自己的代码风格CheckStyle简单使用
  2. mysql: 关于MySQL InnoDB锁行还是锁表?
  3. Logical Volume Manager (Linux)
  4. HttpUtility.UrlEncode,Request.RawUrl,HttpUtility.UrlDecode,HttpUtility.UrlPathEncode,Uri.EscapeDataString
  5. Model Vaildation
  6. 基于struts2的学生报道管理系统(附github源码地址)
  7. 按照eslint 规范写代码 [eslint] &#39;flag&#39; is assigned to itself. (no-self-assign)
  8. Android笔记之获取显示器宽高
  9. HDOJ 4689 Derangement DP
  10. NSString和NSMutableNSString的基本用法