zoukankan      html  css  js  c++  java
  • java POI读取Excel文件

    POI和jxl都能操作Excel,在一开始我选择了jxl来读取Excel文件内容,但在输出读取内容的时候会报错,总结下来就是:

    • jxl只能读取xlsx格式的文件。
    • jxl只能操作2003Excel表格,2007以后的版本则是不可用。

    以上两点只是我个人遇到的问题,最后也是没有解决,所有我是采取了用POI来操作Excel。

    1.导入maven依赖:

    <dependency>
          <groupId>org.apache.poi</groupId>
          <artifactId>poi-ooxml</artifactId>
          <version>3.8</version>
        </dependency>
    <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi-scratchpad</artifactId> <version>3.8</version>
    </dependency>

    2.读取Excel文件内容

     public static List<Area> poi1(){
            List<Area> list=new ArrayList<>();
            try {
                FileInputStream fis = new FileInputStream("F:\f\test1.xlsx");
    //            String city;
                Area area=null;
                XSSFWorkbook workbook =  new XSSFWorkbook(fis);
                XSSFSheet sheet = workbook.getSheetAt(0);
                int firstRowNum = sheet.getFirstRowNum();
                int lastRowNum = sheet.getLastRowNum();
                Row firstRow = sheet.getRow(firstRowNum);
                int firstCellNum = firstRow.getFirstCellNum();
                int lastCellNum = firstRow.getLastCellNum();
                System.out.println("第一行行号:" + firstRowNum);
                System.out.println("最后一行行号:" + lastRowNum);
                System.out.println("第一列列号:" + firstCellNum);
                System.out.println("最后一列列号:" + lastCellNum);

           //我这里是指定了行来获取,如果是获取全部单元格内容的话再加一层for循环即可。
    for(int i = 0; i < lastCellNum; i++) { //System.out.print(sheet.getRow(2).getCell(i).getNumericCellValue() + " "); String city=sheet.getRow(2).getCell(i).getStringCellValue(); String info=sheet.getRow(1).getCell(i).getStringCellValue(); String user=sheet.getRow(0).getCell(i).getStringCellValue(); String type; if (info.equals("")){ type="varchar(10)"; }else type="int"; // //System.out.println(city); area=new Area(city,user,info,type); list.add(area); //System.out.println(list.get(i)); // list.add(sheet.getRow(2).getCell(i).getStringCellValue()); //System.out.println(sheet.getRow(2).getCell(i).getStringCellValue()+" "); //System.out.println(" "); } } catch (FileNotFoundException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } return list; }
  • 相关阅读:
    蓝桥杯Java真题解析
    第十届蓝桥杯JavaB组总结
    Java框架相关
    认识JDBC
    Lua中 MinXmlHttpRequest如何发送post方式数据
    ios 的EditBox点击空白处不隐藏的解决方案
    AssetsManager 在ios更新失败解决方案
    Cocos Studio编辑器运行日志路径
    华为 进入和退出Fastboot、eRecovery和Recovery升级模式
    cocos lua 加密方案
  • 原文地址:https://www.cnblogs.com/1305536110-dym/p/15530488.html
Copyright © 2011-2022 走看看