java excel 显示_[Java教程]poi 输出Excel显示内容

[Java教程]poi 输出Excel显示内容

0 2015-12-04 13:00:16

在业务系统中多少回接触到Excel解析。在java开发平台下选择 Apache POI是一个非常明智的选择,POI提供非常完善API来读取或写入Microsoft Office Excel。

目前对导入的数据都会进行二次加工,我们开发模式就是先把Excel中的内容直接原样导入数据库对应的一张数据表中,然后再进行二次加工。什么是原样,那就是我们在excle看到是什么样的,导入的数据就是什么样的,那怎样实现呢?

首先考虑到,exce另存为csv,然后在解析csv就可以,excel另存为csv后,如下

bc91bb04e6e9c61e24c974e4440db8f2.gif

似乎这样就可以了,但用户上传的Excel文件通过后台转换csv文件也麻烦(PS:其实我都不知道怎么转,有知道的朋友还希望能分享下),说好不是用POI的么,那么接下来我们了解下POI中处理Excel的一些信息

bc91bb04e6e9c61e24c974e4440db8f2.gif

从上图得知,POI类中带HSSF的是处理03格式的,XSSF是处理07以上格式的,废话不多说了,先看看原样输出的一个重要角色 DataFormatter,

查阅官方文档,红框的地方清楚说明了,就是现实Excel中的现实的文本

bc91bb04e6e9c61e24c974e4440db8f2.gif

这里对于公式类型的还需要判断下,

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 }

bc91bb04e6e9c61e24c974e4440db8f2.gif

所以就这么一句代码,就取得的单元格中显示的值,算是大工搞成。ps:解析Excle的完整代码

bc91bb04e6e9c61e24c974e4440db8f2.gif

bc91bb04e6e9c61e24c974e4440db8f2.gif1 private ArrayList 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 }

View Code

2015-12-04

本文网址:http://www.shaoqun.com/a/164094.html

*特别声明:以上内容来自于网络收集,著作权属原作者所有,如有侵权,请联系我们:admin@shaoqun.com。

excel

0

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值