Java利用poi读写Excel需要注意的问题
2012-08-29 14:19
447 查看
碰到的两个主要问题是:(1):整数读取写入(2)日期读取与写入
POI没有提供对整数数据的读取,它提供的数据类型有 HSSFCell.CELL_TYPE_BLANK,HSSFCell.CELL_TYPE_BOOLEAN,HSSFCell.CELL_TYPE_ERROR,HSSFCell.CELL_TYPE_FORMULA,HSSFCell.CELL_TYPE_NUMERIC,HSSFCell.CELL_TYPE_STRING。读取的数字类型为double类型,而不是想要的整数,因此要读取整数的解决方法为,以数字类型读取后直接类型转换 (int)Cell2.getNumericCellValue(),或者以字符读取,Integer.parseInt(Cell1.getRichStringCellValue().getString())。
POI对整数的写入也没提供原函数,不过可以直接把整数做为值写入,cell.setCellValue(1000);其实在函数内部它还是将它转换为了浮点数写入了。
首先判断读取出的单元格类型是否为数字类型 ,如果是数字类型在判断使用为日期格式数据,若是,就将得到的数字值转换为日期。
case HSSFCell.CELL_TYPE_NUMERIC:
if (HSSFDateUtil.isCellDateFormatted(cell)) {
double d = cell.getNumericCellValue();
Date date = HSSFDateUtil.getJavaDate(d);
}
读取数据更保险的方法为:先判断类型,更具不同的类型,采用不同的读取方法。
if(Cell2.getCellType()==HSSFCell.CELL_TYPE_NUMERIC)
{
if(HSSFDateUtil.isCellDateFormatted(Cell2))
{
double d=Cell2.getNumericCellValue();
watchData.setTimeLog(HSSFDateUtil.getJavaDate(d));
}
}else if (Cell2.getCellType()==HSSFCell.CELL_TYPE_STRING) {
SimpleDateFormat sFormat=new SimpleDateFormat("dd-MM-yyyy");
watchData.setTimeLog(sFormat.parse(Cell2.getRichStringCellValue().getString()));
} else{
watchData.setTimeLog(Cell2.getDateCellValue());
}
POI没有提供对整数数据的读取,它提供的数据类型有 HSSFCell.CELL_TYPE_BLANK,HSSFCell.CELL_TYPE_BOOLEAN,HSSFCell.CELL_TYPE_ERROR,HSSFCell.CELL_TYPE_FORMULA,HSSFCell.CELL_TYPE_NUMERIC,HSSFCell.CELL_TYPE_STRING。读取的数字类型为double类型,而不是想要的整数,因此要读取整数的解决方法为,以数字类型读取后直接类型转换 (int)Cell2.getNumericCellValue(),或者以字符读取,Integer.parseInt(Cell1.getRichStringCellValue().getString())。
POI对整数的写入也没提供原函数,不过可以直接把整数做为值写入,cell.setCellValue(1000);其实在函数内部它还是将它转换为了浮点数写入了。
首先判断读取出的单元格类型是否为数字类型 ,如果是数字类型在判断使用为日期格式数据,若是,就将得到的数字值转换为日期。
case HSSFCell.CELL_TYPE_NUMERIC:
if (HSSFDateUtil.isCellDateFormatted(cell)) {
double d = cell.getNumericCellValue();
Date date = HSSFDateUtil.getJavaDate(d);
}
读取数据更保险的方法为:先判断类型,更具不同的类型,采用不同的读取方法。
if(Cell2.getCellType()==HSSFCell.CELL_TYPE_NUMERIC)
{
if(HSSFDateUtil.isCellDateFormatted(Cell2))
{
double d=Cell2.getNumericCellValue();
watchData.setTimeLog(HSSFDateUtil.getJavaDate(d));
}
}else if (Cell2.getCellType()==HSSFCell.CELL_TYPE_STRING) {
SimpleDateFormat sFormat=new SimpleDateFormat("dd-MM-yyyy");
watchData.setTimeLog(sFormat.parse(Cell2.getRichStringCellValue().getString()));
} else{
watchData.setTimeLog(Cell2.getDateCellValue());
}
相关文章推荐
- Java利用poi读写Excel需要注意的问题
- java利用poi包读写excel
- java利用poi读取excel异常问题
- iMOOC学习笔记:Java的Excel读写操作入门实践-利用POI生成Excel文件(一)
- java利用poi 读写(导入导出)word、excel(数组越界求解决办法)
- java服务端利用poi 导出excel 前端需要用表单提交
- 利用Java+POI 读写Excel文档&向Excel中插入图片
- JAVA利用RSA加密算法的长度限制问题解决方案注意: RSA加密明文最大长度117字节,解密要求密文最大长度为128字节,所以在加密和解密的过程中需要分块进行。 RSA加密对明文的长度是有限制的,如
- java利用poi 读写(导入导出)word、excel(数组越界求解决办法)
- 利用java poi对excel表的读写操作
- iMOOC学习笔记:Java的Excel读写操作入门实践-利用POI解析Excel文件(二)
- java poi Excel导入 整数浮点数转换问题解决
- 前2天后台系统需要生成报表,正好抽时间复习了一下之前做过的JAVA生成EXCEL,下面介绍POI 和JXL 生成报表的2种方式。
- 通过本地的eclipse中的java访问远程Linux中的HDFS需要注意的问题.
- java 利用BufferedWriter 读写文件需要flush 缓存
- selenium 学习笔记 ---新手学习记录(10) 问题总结(java)--poi--excel 操作
- Java 利用poi把数据库中数据导入Excel
- Java打成可执行jar过程中需要注意的一些问题
- javaweb 利用poi 导出excel
- java poi导出excel是文件名字符转译问题