Java 操作 Excel (读取Excel2007,Poi实现)

    技术2022-05-19  23

    Java 操作 Excel (读取Excel2007,Poi实现)

    今天做excel 文件导入,用平时一直用的jxl包实现,可是一直出现 "Unable to recognize OLE stream "这个错误,上网查询了一下,所来JXL不支持EXCEL2007上传。看到这样一篇文章,转来学习一下。

    查看了一下Poi,最新的  POI 3.5 beta 4 支持读写 Excel2007和PPT2007(XLSX and PPTX),自己来实现Java读取Excel2007了。

     

    1,下载 POI 3.5 beta 4 解压,把其中的jar包导入项目文件。以我的读取为例,导入了以下jar包。

     没有配置 log4j,测试时报告警报信息,应该为加载顺序导致的初始化问题造成(暂时没有找原因)。

    2.建立读取2007方法

     

    Java代码    // 构造 XSSFWorkbook 对象,strPath 传入文件路径  XSSFWorkbook xwb = new XSSFWorkbook(strPath);  // 读取第一章表格内容  XSSFSheet sheet = xwb.getSheetAt(0);  // 定义 row、cell  XSSFRow row;  String cell;  // 循环输出表格中的内容  for (int i = sheet.getFirstRowNum(); i < sheet.getPhysicalNumberOfRows(); i++) {      row = sheet.getRow(i);      for (int j = row.getFirstCellNum(); j < row.getPhysicalNumberOfCells(); j++) {          // 通过 row.getCell(j).toString() 获取单元格内容,          cell = row.getCell(j).toString();          System.out.print(cell + "/t");      }      System.out.println("");  }  

     

    此过程直接传入文件所在路径,其他一些过程已经被自动实现。

     

    3.测试,文件为8列3563行数据,以文本方式读取内容

    Java代码    public static void main(String[] args) {      SimpleDateFormat sdf = new SimpleDateFormat("HH:mm:ss:SS");      TimeZone t = sdf.getTimeZone();      t.setRawOffset(0);      sdf.setTimeZone(t);      Long startTime = System.currentTimeMillis();      String fileName = "F://我的文档//学生缴费代码.xlsx";      // 检测代码      try {          PoiReadExcel er = new PoiReadExcel();          // 读取excel2007          er.testPoiExcel2007(fileName);      } catch (Exception ex) {          Logger.getLogger(FastexcelReadExcel.class.getName()).log(Level.SEVERE, null, ex);      }      Long endTime = System.currentTimeMillis();      System.out.println("用时:" + sdf.format(new Date(endTime - startTime)));  }  

     


    最新回复(0)