关闭

POI实战-java开发excel详解之单元格各类型数据读取

标签: web框架excelpoi
5828人阅读 评论(0) 收藏 举报
分类:

2.复杂读取

2.1 单元格各类型数据读取

2.1.1 基本类型

在实际工作中,我们处理的Excel数据都不止限于字符型数据,更多的是数字、日期、甚至公式等。

下面是单元格类型说明:

类型

 

CELL_TYPE_BLANK

空值(cell不为空)

CELL_TYPE_BOOLEAN

布尔

CELL_TYPE_ERROR

错误

CELL_TYPE_FORMULA

公式

CELL_TYPE_STRING

字符串

CELL_TYPE_NUMERIC

数值

以上单元格的类型,可以通过getCellType()方法获得,返回值为int。

下面读取一个多类型数据Excel文件:

图7中,数据文件格式包括字符、数字、公式、布尔。


图7

代码片段:

[java] view plaincopy
  1. public static void read(InputStream inputStream) throws IOException{  
  2.         HSSFWorkbook workbook = new HSSFWorkbook(inputStream);  
  3.         //循环workbook中所有sheet  
  4.         for(int sheetIndex = 0; sheetIndex < workbook.getNumberOfSheets(); sheetIndex++){  
  5.             HSSFSheet sheet = workbook.getSheetAt(sheetIndex);  
  6.             //循环该sheet中的有数据的每一行  
  7.             for(int rowIndex = 0; rowIndex <= sheet.getLastRowNum(); rowIndex++){  
  8.                 HSSFRow row = sheet.getRow(rowIndex);  
  9.                 if(row == null){  
  10.                     continue;  
  11.                 }  
  12.                 //循环该行的每一个单元格  
  13.                 for(int cellnum = 0; cellnum < row.getLastCellNum(); cellnum++){  
  14.                     HSSFCell cell = row.getCell(cellnum);  
  15.                     getCellValue(cell, rowIndex, cellnum);  
  16.                 }  
  17.             }  
  18.         }  
  19.     }  
  20.   
  21.   
  22. public static void getCellValue(HSSFCell cell, int rowIndex, int cellnum){  
  23.         if(cell == null){  
  24.             return;  
  25.         }else if(cell.getCellType() == HSSFCell.CELL_TYPE_BLANK){  
  26.             System.out.println("第"+(rowIndex+1)+"行,第"+(cellnum+1)+"列  cellType为:CELL_TYPE_BLANK");  
  27.         }else if(cell.getCellType() == HSSFCell.CELL_TYPE_STRING){  
  28.             System.out.println("第"+(rowIndex+1)+"行,第"+(cellnum+1)+"列  cellType为:CELL_TYPE_STRING  值为:"+cell.getRichStringCellValue().getString());  
  29.         }else if(cell.getCellType() == HSSFCell.CELL_TYPE_NUMERIC){  
  30.             System.out.println("第"+(rowIndex+1)+"行,第"+(cellnum+1)+"列  cellType为:CELL_TYPE_NUMERIC  值为:"+cell.getNumericCellValue());  
  31.         }else if(cell.getCellType() == HSSFCell.CELL_TYPE_BOOLEAN){  
  32.             System.out.println("第"+(rowIndex+1)+"行,第"+(cellnum+1)+"列  cellType为:CELL_TYPE_BOOLEAN  值为:"+cell.getBooleanCellValue());  
  33.         }else if(cell.getCellType() == HSSFCell.CELL_TYPE_FORMULA){  
  34.             System.out.println("第"+(rowIndex+1)+"行,第"+(cellnum+1)+"列  cellType为:CELL_TYPE_FORMULA  值为:"+cell.getNumericCellValue()+" 公式为:"+cell.getCellFormula());  
  35.         }  
  36.         return;  
  37.     }  
  38.       

打印预览:


注:公式格式的单元格值为数字,所以取值的时候是通过cell.getNumericCellValue()方法,而取单元格的公式需要通过cell.getCellFormula()方法。

2.1.2 日期类型

Excel中的Date类型以Double型数字存储的,表示当前时间与1900年1月1日相隔的天数。所以在Excel中如果单元格格式为NUMERIC类型还需要进一步判断是否为日期类型。在读取日期单元格时需要调用HSSFDateUtil的isCellDateFormatted方法,来判断该Cell的数据格式是否是Date类型,然后通过HSSFCell的getDateCellValue方法获取Date。

如图9,在之前Excel数据后新加了Date格式的数据


图9

 

代码片段:

[java] view plaincopy
  1. public static void getCellValue(HSSFCell cell, int rowIndex, int cellnum){  
  2.         if(cell == null){  
  3.             return;  
  4.         }else if(cell.getCellType() == HSSFCell.CELL_TYPE_BLANK){  
  5.             System.out.println("第"+(rowIndex+1)+"行,第"+(cellnum+1)+"列  cellType为:CELL_TYPE_BLANK");  
  6.         }else if(cell.getCellType() == HSSFCell.CELL_TYPE_STRING){  
  7.             System.out.println("第"+(rowIndex+1)+"行,第"+(cellnum+1)+"列  cellType为:CELL_TYPE_STRING  值为:"+cell.getRichStringCellValue().getString());  
  8.         }else if(cell.getCellType() == HSSFCell.CELL_TYPE_NUMERIC){  
  9.              if(HSSFDateUtil.isCellDateFormatted(cell)){  
  10.                     Date date = cell.getDateCellValue();  
  11.                     SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd");  
  12.                     System.out.println("第"+(rowIndex+1)+"行,第"+(cellnum+1)+"列  cellType为:Date 值为:"+dateFormat.format(date));  
  13.             }else{  
  14.             System.out.println("第"+(rowIndex+1)+"行,第"+(cellnum+1)+"列  cellType为:CELL_TYPE_NUMERIC  值为:"+cell.getNumericCellValue());  
  15.             }  
  16.         }else if(cell.getCellType() == HSSFCell.CELL_TYPE_BOOLEAN){  
  17.             System.out.println("第"+(rowIndex+1)+"行,第"+(cellnum+1)+"列  cellType为:CELL_TYPE_BOOLEAN  值为:"+cell.getBooleanCellValue());  
  18.         }else if(cell.getCellType() == HSSFCell.CELL_TYPE_FORMULA){  
  19.             System.out.println("第"+(rowIndex+1)+"行,第"+(cellnum+1)+"列  cellType为:CELL_TYPE_FORMULA  值为:"+cell.getNumericCellValue()+" 公式为:"+cell.getCellFormula());  
  20.         }  
  21.         return;  
  22.     }  


打印预览:


 图10

2.2 自定义类型

在Excel中有许多种数据格式,并且支持用户自定义格式。如图11。可以通过HSSFDataFormat类进行操作。getBuiltinFormat(short index)方法根据编号返回内置数据类型,getBuiltinFormat(java.lang.Stringformat)方法根据数据类型返回其编号,getBuiltinFormats()返回整个内置的数据格式列表。


图11

HSSFDataFormat的数据格式

内置数据类型

编号

"General"

0

"0"

1

"0.00"

2

"#,##0"

3

"#,##0.00"

4

"($#,##0_);($#,##0)"

5

"($#,##0_);[Red]($#,##0)"

6

"($#,##0.00);($#,##0.00)"

7

"($#,##0.00_);[Red]($#,##0.00)"

8

"0%"

9

"0.00%"

0xa

"0.00E+00"

0xb

"# ?/?"

0xc

"# ??/??"

0xd

"m/d/yy"

0xe

"d-mmm-yy"

0xf

"d-mmm"

0x10

"mmm-yy"

0x11

"h:mm AM/PM"

0x12

"h:mm:ss AM/PM"

0x13

"h:mm"

0x14

"h:mm:ss"

0x15

"m/d/yy h:mm"

0x16

保留为过国际化用

0x17 - 0x24

"(#,##0_);(#,##0)"

0x25

"(#,##0_);[Red](#,##0)"

0x26

"(#,##0.00_);(#,##0.00)"

0x27

"(#,##0.00_);[Red](#,##0.00)"

0x28

"_($*#,##0_);_($*(#,##0);_($* \"-\"_);_(@_)"

0x29

"_(*#,##0.00_);_(*(#,##0.00);_(*\"-\"??_);_(@_)"

0x2a

"_($*#,##0.00_);_($*(#,##0.00);_($*\"-\"??_);_(@_)"

0x2b

"_($*#,##0.00_);_($*(#,##0.00);_($*\"-\"??_);_(@_)"

0x2c

"mm:ss"

0x2d

"[h]:mm:ss"

0x2e

"mm:ss.0"

0x2f

"##0.0E+0"

0x30

"@" - This is text format

0x31


0
0
查看评论

POI 设置和获取excel单元格格式

public static void readExpectSheetAndWriteCaseSheet(matchAndNotMatchExcelObject matchExcelResult, String filePath) {   try {   ...
  • qitehuanjue
  • qitehuanjue
  • 2016-08-29 18:07
  • 2198

POI读取Excel 各种特殊数字和类型的转换。取值带一个E

1, 对于类似电话号码或手机一类的大数值读取问题  // 取值后会带一个E的问题 double cellValue = row.getCell(k).getNumericCellValue(); fieldValues[k] = new DecimalFormat("#...
  • johnstrive
  • johnstrive
  • 2012-12-23 15:47
  • 44633

【JAVA】apache poi excel 文件读取,各种数据类型,不规则excel格式都可以读取

本文将通过实例来介绍apache poi  读取excel的原理,包括各种数据类型的处理,本文提供的代码非常通用,即使不规则的excel文件,也可以读取。 直接看代码吧 package poi.excel; import java.io.File; import java.text.De...
  • chiweitree
  • chiweitree
  • 2015-12-30 11:13
  • 6065

POI Excel 单元格内容类型判断并取值

做Excel导入功能时,读取Excel单元格内容需要区分类型switch (cell.getCellType()) { case HSSFCell.CELL_TYPE_NUMERIC: // 数字 //如果为时间格式的内容 if (HSSFDate...
  • f1204270443
  • f1204270443
  • 2017-01-04 15:15
  • 6499

POI对Excel单元格的格式的设置参数

需求最近在做导出时,遇到了时间格式变成了纯数字。环境poi java 1.8解决方式日期格式:cell.setCellValue(new Date(2008,5,5)); //set date format CellStyle cellStyle = workBook.createCellStyl...
  • u013066244
  • u013066244
  • 2016-12-29 18:11
  • 1893

POI对Excel的单元格格式区分

第一段:Excel的单元格格式 图中的数据有数值、货币、时间、日期、文本等格式。这些数据格式在POI中的HSSFDataFormat类里都有相应的定义。 HSSFDataFormat是HSSF子项目里面定义的一个类。类HSSFDataFormat允许用户新建数据格式类型。HSSFDataF...
  • u011303664
  • u011303664
  • 2015-10-27 15:29
  • 1212

POI获取单元格值

public static Object getCellValue(HSSFCell cell) { Object value = ""; if (cell.getCellType() == HSSFCell.CELL_TYPE_STRING) { value = ...
  • u013183865
  • u013183865
  • 2015-01-04 13:43
  • 1828

POI获取Excel中单元格内容时,如果为数字格式获取类型为double的问题

 Apache POI是Apache软件基金会的开放源码函式库,POI提供API给Java程序对Microsoft Office格式档案读和写的功能。 当采用默认的单元格格式,当单元格中为纯数字时,例如 当如下获取时,得到的却是41000.0 // 商品编号 String prod...
  • honghailiang888
  • honghailiang888
  • 2015-11-02 10:46
  • 4855

如何将excel单元格的默认格式设置为常规格式

我的excel不知道为什么,新建表格的时候默认的单元格格式是日期格式。 解决方法:设置单元格格式-选择数字-选择自定义-找到类似于这样的格式([$-409]d-mmm-yyyy h:mm AM/PM;@),删除之即可恢复
  • fishernemo
  • fishernemo
  • 2015-09-16 10:18
  • 2484

java读取Excel的方法,解析xls、xlsx两种格式

import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.IOException; import java.io.InputStream; import java.util.Date; i...
  • superdog007
  • superdog007
  • 2015-09-10 09:21
  • 43447
    个人资料
    • 访问:585964次
    • 积分:8202
    • 等级:
    • 排名:第2971名
    • 原创:171篇
    • 转载:575篇
    • 译文:0篇
    • 评论:35条
    座右铭

    细节决定成败,

    态度决定一切。

    博客专栏
    最新评论