poi 输出Excel显示内容

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

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

   首先考虑到,exce另存为csv,而后在解析csv就能够,excel另存为csv后,以下ide

   

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

  

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

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

      

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

      

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的完整代码orm

 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     }
View Code

                                                                                                                                                                                  2015-12-04 blog

相关文章
相关标签/搜索