POI解析单元格格式
来源:互联网 发布:cdn网络加速 书 编辑:程序博客网 时间:2024/05/22 12:53
cell.getCellStyle().getDataFormat();根据这个值进行时间、日期格式的判断;POI读取出来的结果也是有些变化的;需要在实际项目中进行确认;日期格式的遍历:Excel2007和Excel2003都是这样的结果;
时间格式的遍历:
增加了其它日期格式的处理:
// 读取cell单元格的值,如果为日期格式,进行转换 @SuppressWarnings("deprecation") public String parseCell(Cell cell) { if (cell == null) return ""; if (cell.getCellType() == Cell.CELL_TYPE_STRING) { return cell.getStringCellValue(); } else if (cell.getCellType() == Cell.CELL_TYPE_BOOLEAN) { return String.valueOf(cell.getBooleanCellValue()); } else if (cell.getCellType() == Cell.CELL_TYPE_FORMULA) { return cell.getCellFormula(); } else if (cell.getCellType() == Cell.CELL_TYPE_NUMERIC) { short format = cell.getCellStyle().getDataFormat(); SimpleDateFormat sdf = null; if (format == 14 || format == 31 || format == 57 || format == 58 || (176<=format && format<=178) || (182<=format && format<=196) || (210<=format && format<=213) || (208==format ) ) { // 日期 sdf = new SimpleDateFormat("yyyy-MM-dd"); } else if (format == 20 || format == 32 || format==183 || (200<=format && format<=209) ) { // 时间 sdf = new SimpleDateFormat("HH:mm"); } else { // 不是日期格式
cell.setCellType(Cell.CELL_TYPE_STRING); return cell.getRichStringCellValue().toString().trim(); //return String.valueOf(cell.getNumericCellValue());这样会导致excel单元格设置为文本,但是存储数字的读取到的字符串为2.123E5之类的指数类型,所以笔者选择上面的处理方式将非日期的单元格先强制设置为文本格式,然后按照文本格式读取! } double value = cell.getNumericCellValue(); Date date = org.apache.poi.ss.usermodel.DateUtil.getJavaDate(value); if(date==null || "".equals(date)){ return ""; } String result=""; try { result = sdf.format(date); } catch (Exception e) { e.printStackTrace(); return ""; } return result; } return "";}
需要注意的是:在调用getCellValue方法之前不用设置该单元格格式,否则解析有可能不成功(因为你不知道单元格格式,除非你采用getCellValue方法内部的方式判断--冗余代码)。
参考文章:https://www.cnblogs.com/stono/p/6713158.html
阅读全文
1 0
- POI解析单元格格式
- POI 单元格格式
- POI 创建日期格式单元格
- POI设置Excel单元格格式
- POI 设置EXCEL单元格格式
- POI中设置Excel单元格格式
- POI中设置Excel单元格格式
- java设置Excel单元格格式 POI
- POI中设置Excel单元格格式
- POI设置EXCEL单元格的"条件格式"
- 使用POI设置EXCEL单元格格式
- POI中设置Excel单元格格式
- poi 设置单元格 格式为 数据有效性
- POI 设置Excel单元格为文本格式
- POI中设置Excel单元格格式
- POI中设置Excel单元格格式
- POI中设置Excel单元格格式
- POI中设置Excel单元格格式
- 三大框架 SSM 搭建基础项目 Maven
- 文件描述符
- SQL建表字段语法DEFAULT和字段 NULL的组合定义表现
- python——pandas的pivot_table使用
- 安卓开发中的排序
- POI解析单元格格式
- Universal 2nd Factor (U2F) 概述(5)-用户提醒:设备“激活”和浏览器提示
- java继承多态和抽象类接口
- spring boot实战(第一篇)第一个案例
- 用FaceNet的模型计算人脸之间距离(TensorFlow)
- 计算机经典编程书籍大全!附下载地址
- ROS学习笔记10 话题(topics)实例
- 单链表判断环路及环路的入口
- linux netstat