poi 输出Excel显示内容
在业务系统中多少回接触到Excel解析。在java开发平台下选择 Apache POI是一个非常明智的选择,POI提供非常完善API来读取或写入Microsoft Office Excel。
目前对导入的数据都会进行二次加工,我们开发模式就是先把Excel中的内容直接原样导入数据库对应的一张数据表中,然后再进行二次加工。什么是原样,那就是我们在excle看到是什么样的,导入的数据就是什么样的,那怎样实现呢?
首先考虑到,exce另存为csv,然后在解析csv就可以,excel另存为csv后,如下
似乎这样就可以了,但用户上传的Excel文件通过后台转换csv文件也麻烦(PS:其实我都不知道怎么转,有知道的朋友还希望能分享下),说好不是用POI的么,那么接下来我们了解下POI中处理Excel的一些信息
从上图得知,POI类中带HSSF的是处理03格式的,XSSF是处理07以上格式的,废话不多说了,先看看原样输出的一个重要角色 DataFormatter,
查阅官方文档,红框的地方清楚说明了,就是现实Excel中的现实的文本
这里对于公式类型的还需要判断下,
1 DataFormatter df = new DataFormatter(); 2 if (cell.getCellType() == cell.CELL_TYPE_FORMULA) { 3 FormulaEvaluator formulaEval = wb.getCreationHelper().createFormulaEvaluator(); 4 value = df.formatCellValue(cell, formulaEval); 5 } else { 6 value = df.formatCellValue(cell); 7 }
所以就这么一句代码,就取得的单元格中显示的值,算是大工搞成。ps:解析Excle的完整代码

1 private ArrayList<String[]> GetExcel(String filename) 2 throws FileNotFoundException, IOException, Exception { 3 File f = new File(filename); 4 ArrayList data = new ArrayList(); 5 if (f.exists()) { 6 InputStream fis = new FileInputStream(f); 7 Workbook wb = WorkbookFactory.create(fis); 8 Sheet fst = wb.getSheetAt(0); 9 int rowcount = fst.getLastRowNum(); 10 Row headrow = fst.getRow(0); 11 int colcount = headrow.getLastCellNum(); 12 for (int ri = 0; ri <= rowcount; ri++) { 13 System.out.println(""); 14 System.out.println("第" + ri + "行数据"); 15 String[] colValues = new String[colcount]; 16 Row row = fst.getRow(ri); 17 for (int i = 0; i < colcount; i++) { 18 Cell cell = row.getCell(i); 19 String value = ""; 20 if (cell != null) { 21 DataFormatter df = new DataFormatter(); 22 if (cell.getCellType() == cell.CELL_TYPE_FORMULA) { 23 FormulaEvaluator formulaEval = wb.getCreationHelper().createFormulaEvaluator(); 24 value = df.formatCellValue(cell, formulaEval); 25 } else { 26 value = df.formatCellValue(cell); 27 } 28 } 29 colValues[i] = value; 30 System.out.print(colValues[i] + "--"); 31 } 32 data.add(colValues); 33 } 34 } 35 f.delete(); 36 return data; 37 }
2015-12-04
- 转载请注明来源
- 作者:杨瀚博
- QQ:464884492
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
· [.NET]调用本地 Deepseek 模型
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· .NET Core 托管堆内存泄露/CPU异常的常见思路
· PostgreSQL 和 SQL Server 在统计信息维护中的关键差异
· DeepSeek “源神”启动!「GitHub 热点速览」
· 微软正式发布.NET 10 Preview 1:开启下一代开发框架新篇章
· C# 集成 DeepSeek 模型实现 AI 私有化(本地部署与 API 调用教程)
· DeepSeek R1 简明指南:架构、训练、本地部署及硬件要求
· 2 本地部署DeepSeek模型构建本地知识库+联网搜索详细步骤