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包

java调用POI读取Excel的更多相关文章

  1. JAVA使用POI读取EXCEL文件的简单model

    一.JAVA使用POI读取EXCEL文件的简单model 1.所需要的jar commons-codec-1.10.jarcommons-logging-1.2.jarjunit-4.12.jarlo ...

  2. Java之POI读取Excel的Package should contain a content type part [M1.13]] with root cause异常问题解决

    Java之POI读取Excel的Package should contain a content type part [M1.13]] with root cause异常问题解决 引言: 在Java中 ...

  3. java用poi读取Excel表格中的数据

    Java读写Excel的包是Apache POI(项目地址:http://poi.apache.org/),因此需要先获取POI的jar包,本实验使用的是POI 3.9稳定版.Apache POI 代 ...

  4. Java实现POI读取Excel文件,兼容后缀名xls和xlsx

    1.引入所需的jar包: maven管理项目的话直接添加以下坐标即可: <!-- https://mvnrepository.com/artifact/org.apache.poi/poi -- ...

  5. java 使用POI读取excel数据

    原文:http://doc.okbase.net/0201zcr/archive/161440.html 一.定义 Apache POI是Apache软件基金会的开放源码函式库,POI提供API给Ja ...

  6. java通过poi读取excel中的日期类型数据或自定义类型日期

    Java 读取Excel表格日期类型数据的时候,读出来的是这样的  12-十月-2019,而Excel中输入的是 2019/10/12 或 2019-10-12 poi处理excel时,当excel没 ...

  7. Java利用POI读取Excel

    官网直接下载POI  http://poi.apache.org/ package com.CommonUtil; import java.io.File; import java.io.FileIn ...

  8. java使用POI读取excel报表

    留此作为记录 package com.demo; import java.io.FileInputStream; import java.util.Iterator; import org.apach ...

  9. java利用poi读取excel异常问题

    最近一个web工程需要完成一个小功能,利用文件上传然后读取文件内容写入到数据库,这里是操作的excel文件,excel文件分两种后缀,03版本的xls和之后的xlsx,现在大家一般都拿非常好用的插件直 ...

随机推荐

  1. VueJS处理逻辑指令:v-if

    HTML <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <titl ...

  2. UE-9260使用说明2

    生成镜像 1. U-boot 生成u-boot.bin文件 (1) Makefile ifeq ($(ARCH),arm) CROSS_COMPILE = endif 改动为 ifeq ($(ARCH ...

  3. 浅析嵌入式C优化技巧

    嵌入式C语言优化小技巧 1 概述 嵌入式系统是指完毕一种或几种特定功能的计算机系统,具有自己主动化程度高,响应速度快等长处,眼下已广泛应用于消费电子,工业控制等领域.嵌入式系统受其使用的硬件以及运行环 ...

  4. g++ 6.4编译opencv-2.4.10报错记录

      fetch公司的项目进行编译,此项目依赖opencv库.由于本人一直比较偏爱fedora,但也因此给我带来了许多"乐趣"(麻烦).fedora一直走得比较前沿,g++ 6.3了 ...

  5. Asp.Net Core 初探 (三)

    昨天失败的生产环境部署就先放着,明天再解决! 今天利用中午的空余时间看了一下Asp.net core 的Areas . 相对于Asp.net MVC5 以及之前的版本,asp.net core 的Ar ...

  6. php pack()函数详解与示例

    pack和unpack在一般的程序中还真的不容易见到,但是如果你用过很久以前的php生成excel你就会知道了.他的excel的头就是pack出来的最近在尝试与C交互的时候又用上了这玩意,所以不得不再 ...

  7. Edit conflicts

    Edit conflicts 当副本修改处和服务器版本相同处被修改并下载到本地时,就会发生文件冲突. 操作步骤如下所示: Ø 执行"SVN Update" Ø 若发生冲突,会出现如 ...

  8. CAS 单点登录原理

    访问服务: 浏览器发送请求访问应用系统 定向认证: 应用系统重定向用户请求到 SSO 服务器. 用户认证:用户身份认证. 发放票据: 认证通过后,SSO 服务器会产生一个随机的 Service Tic ...

  9. hdu5258简单枚举

    百度之星复赛第一题.不明白这么水的题为何一堆人没过...这些人是咋晋级复赛的呢... /* * Author : ben */ #include <cstdio> #include < ...

  10. [2017-09-05]Abp系列——Abp后台作业系统介绍与经验分享

    本系列目录:Abp介绍和经验分享-目录 什么是后台作业系统 后台作业系统即BackgroundJob,从需求上讲,是一套基础设施,允许我们定义一个作业,在未来指定的某个时间去执行. 后台作业的一般场景 ...