POI读取Excel时数据类型转换的问题
2015-07-24 09:44
148 查看
1. 数值类型处理
通过POI取出的数值默认都是double,即使excel单元格中存的是1,取出来的值也是1.0,这就造成了一些问题,如果数据库字段是int,那么就会wrong data type,所以需要对数值类型处理。
这么处理后,单元格中的小数没有变化,如果是整数,也会取到整数。
注:由于电子表格只能支持15位数值的显示,当数值大于15位时会造成数据丢失,所以对于处理大于15位的学号身份证号等数值信息,建议以text格式存储,在读取的时候:
2. 日期类型处理
很遗憾,POI对单元格日期处理很弱,没有针对的类型,日期类型取出来的也是一个double值,所以同样作为数值类型。
转换成Timestamp格式:
可以判断得到的Date是日期时间、日期还是时间,可以通过cell.getCellStyle().getDataFormat()来判断,这个返回值没有一个常量值来对应,我本机是excel2013,测试结果是日期时间(yyyy-MM-dd HH:mm:ss) - 22,日期(yyyy-MM-dd) - 14,时间(HH:mm:ss) - 21,年月(yyyy-MM) - 17,时分(HH:mm) - 20,月日(MM-dd) - 58,有了这个,可以根据数据库字段类型,处理之后再入库,相当不方便。
另外,如果单元格数据格式是自定义的日期格式,那么通过DateUtil.isCellDateFormatted(cell)判断不出来,而且该单元格还是一个数值单元格,返回一个double值,这里比较2。针对这种方式,有两种解决方案,第一种,重写DateUtil.isCellDateFormatted(cell)方法,开源的都有源码;第二种,cell.getCellStyle().getDataFormatString()来判断,这个方法会返回格式字符串,通过这个字符串去匹配,再处理。
附单元格数据类型:
|Cell.CELL_TYPE_NUMERIC 数值类型 cell.getNumericCellValue()||或cell.getDateCellValue()|
|Cell.CELL_TYPE_STRING 字符串类型 cell.getStringCellValue()||或cell.toString()|
|Cell.CELL_TYPE_BOOLEAN 布尔类型 cell.getBooleanCellValue()|
|Cell.CELL_TYPE_FORMULA 表达式类型 cell.getCellFormula()|
|Cell.CELL_TYPE_ERROR 异常类型||不知道何时算异常 cell.getErrorCellValue()|
|Cell.CELL_TYPE_BLANK 空,不知道何时算空 空就不要取值了吧|
通过POI取出的数值默认都是double,即使excel单元格中存的是1,取出来的值也是1.0,这就造成了一些问题,如果数据库字段是int,那么就会wrong data type,所以需要对数值类型处理。
Cell cell = null;// 单元格
Object inputValue = null;// 单元格值
if(!isEmpty(cell) && cell.getCellType() == Cell.CELL_TYPE_NUMERIC) {
long longVal = Math.round(cell.getNumericCellValue());
if(Double.parseDouble(longVal + ".0") == doubleVal)
inputValue = longVal;
else
inputValue = doubleVal;
}
这么处理后,单元格中的小数没有变化,如果是整数,也会取到整数。
注:由于电子表格只能支持15位数值的显示,当数值大于15位时会造成数据丢失,所以对于处理大于15位的学号身份证号等数值信息,建议以text格式存储,在读取的时候:
Long id=new Long(cell.toSting());
2. 日期类型处理
很遗憾,POI对单元格日期处理很弱,没有针对的类型,日期类型取出来的也是一个double值,所以同样作为数值类型。
Cell cell = null;// 单元格
Object inputValue = null;// 单元格值
if(!isEmpty(cell) && cell.getCellType() == Cell.CELL_TYPE_NUMERIC) {
if(DateUtil.isCellDateFormatted(c))// 判断单元格是否属于日期格式
inputValue = cell.getDateCellValue();//java.util.Date类型
}
转换成Timestamp格式:
Timestamp time=new Timestamp(inputValue.getTime());
可以判断得到的Date是日期时间、日期还是时间,可以通过cell.getCellStyle().getDataFormat()来判断,这个返回值没有一个常量值来对应,我本机是excel2013,测试结果是日期时间(yyyy-MM-dd HH:mm:ss) - 22,日期(yyyy-MM-dd) - 14,时间(HH:mm:ss) - 21,年月(yyyy-MM) - 17,时分(HH:mm) - 20,月日(MM-dd) - 58,有了这个,可以根据数据库字段类型,处理之后再入库,相当不方便。
另外,如果单元格数据格式是自定义的日期格式,那么通过DateUtil.isCellDateFormatted(cell)判断不出来,而且该单元格还是一个数值单元格,返回一个double值,这里比较2。针对这种方式,有两种解决方案,第一种,重写DateUtil.isCellDateFormatted(cell)方法,开源的都有源码;第二种,cell.getCellStyle().getDataFormatString()来判断,这个方法会返回格式字符串,通过这个字符串去匹配,再处理。
附单元格数据类型:
|Cell.CELL_TYPE_NUMERIC 数值类型 cell.getNumericCellValue()||或cell.getDateCellValue()|
|Cell.CELL_TYPE_STRING 字符串类型 cell.getStringCellValue()||或cell.toString()|
|Cell.CELL_TYPE_BOOLEAN 布尔类型 cell.getBooleanCellValue()|
|Cell.CELL_TYPE_FORMULA 表达式类型 cell.getCellFormula()|
|Cell.CELL_TYPE_ERROR 异常类型||不知道何时算异常 cell.getErrorCellValue()|
|Cell.CELL_TYPE_BLANK 空,不知道何时算空 空就不要取值了吧|
相关文章推荐
- poi读取Excel文件并进行数据类型转换实例
- POI读取Excel 各种特殊数字和类型的转换。
- POI读取Excel 各种特殊数字和类型的转换。
- poi读取excel兼容(2003、2007)各种数据类型
- 从Excel中读取数据,关于一列数据包含多种数据类型的问题
- POI读取Excel 各种特殊数字和类型的转换。取值带一个E
- POI读取Excel数据类型的判断方法
- java通过poi读取excel中的日期类型数据或自定义类型日期
- Java 读取Excel表格数据日期类型转换
- POI读取Excel 各种特殊数字和类型的转换
- POI读取Excel 各种特殊数字和类型的转换
- SQL C# nvarchar类型转换为int类型 多表查询的问题,查询结果到新表,TXT数据读取到控件和数据库,生成在控件中的数据如何存到TXT文件中
- POI读取Excel 各种特殊数字和类型的转换
- 【JAVA】apache poi excel 文件读取,各种数据类型,不规则excel格式都可以读取
- 【JAVA】apache poi excel 文件读取,各种数据类型,不规则excel格式都可以读取
- 使用poi读取Excel中的各种数据类型处理
- Java使用poi读取excel数据(excel可能很大,先转换为csv再读取)
- 利用POI将读取的数据写入Excel
- 参数中有const时进行数据类型的转换问题-固定变量转常量
- 解决struts2基础数据类型自动转换,输入字母报错问题!