java 获取excel文件数据POI

###在Java中,HSSFWorkbook、XSSFWorkbook和SXSSFWorkbook都是Apache POI库中用于处理Excel文件的类。它们之间的主要区别如下:

HSSFWorkbook:它是POI库中处理旧版Excel(.xls)文件的类。HSSFWorkbook基于OLE2 Compound Document Format,适用于Excel 97-2003版本。它使用的是基于二进制格式的文件结构。HSSFWorkbook的缺点是对大量数据的处理效率相对较低。

XSSFWorkbook:它是POI库中处理新版Excel(.xlsx)文件的类。XSSFWorkbook基于Office Open XML格式,适用于Excel 2007及更高版本。它使用的是基于XML的文件结构。相比HSSFWorkbook,XSSFWorkbook支持更多的Excel特性,并且在处理大量数据时有更好的性能。

SXSSFWorkbook:它是POI库中处理大型Excel文件的类。SXSSFWorkbook是一种流式操作的工作簿,可用于处理超出内存限制的大型数据集。SXSSFWorkbook将数据写入临时文件而不是完全加载到内存中,因此可以处理非常大的Excel文件而不会导致内存溢出。这对于需要处理数百万行数据或占用大量内存的情况非常有用。

#####总结:HSSFWorkbook适用于旧版Excel文件(.xls),XSSFWorkbook适用于新版Excel文件(.xlsx),而SXSSFWorkbook适用于处理大型Excel文件,特别是涉及大量数据的情况。选择适合您需求的POI工作簿类可以提高性能和功能的使用体验。

###1. 导包:

        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi</artifactId>
            <version>4.0.1</version>
        </dependency>
        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi-ooxml</artifactId>
            <version>4.0.1</version>
        </dependency>
        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi-ooxml-schemas</artifactId>
            <version>4.0.1</version>
        </dependency>

###2. 代码块

import org.apache.poi.xssf.usermodel.XSSFRow;
import org.apache.poi.xssf.usermodel.XSSFSheet;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;

      XSSFWorkbook workbook = null;
        try {
            workbook = new XSSFWorkbook(new File("D:\\templateExcel\\test.xlsx"));
            //获取excel下的所有sheet页
            int numberSheets = workbook.getNumberOfSheets();
            System.out.println("sheet总页数:" + numberSheets);
            int i = 0;
            while (i < numberSheets){
                System.out.println("读取第" + (i+1) + "个sheet页");
                XSSFSheet sheetAt = workbook.getSheetAt(i);
                //获取最后一行,总行数
                int lastRowNum = sheetAt.getLastRowNum();
                if (lastRowNum == 0){
                    System.out.println("sheet页"+(i+1)+"无数据!");
                    continue;
                }
                //循环每一行 此处从0开始
                for(int h = 0; h <= lastRowNum; h++){
                    //获取行数据
                    XSSFRow row = sheetAt.getRow(h);
                    System.out.println("一行中单元格数" + row.getLastCellNum());
                    //循环每一行的格子 即总单元格数 ***注意:此处从1开始计数***
                    for (int g = 0; g < row.getLastCellNum(); g++){
                        System.out.println("第"+ (h+1) +"行,第"+ (g+1) +"列数据:" + row.getCell(g));
                    }
                }
                i++;
            }
            workbook.close();
        } catch (Exception e) {
            e.printStackTrace();
        }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java使用POI库可以实现对Excel文件的读取操作。具体的步骤如下: 1. 引用POI库。在Java项目中引入POI相关的jar包。 2. 创建文件输入流。使用FileInputStream类创建一个输入流对象,并指定要读取的Excel文件路径。 3. 创建工作簿对象。使用HSSFWorkbook类创建一个工作簿对象,将输入流作为参数传入。 4. 获取工作表。使用getSheetAt方法获取指定的工作表,可以通过工作表的索引或名称进行获取。 5. 获取行。使用getRow方法获取指定行的对象,行号作为参数传递给该方法。 6. 获取单元格。使用getCell方法获取指定单元格的对象,行号和列号作为参数传递给该方法。 7. 获取单元格的值。使用getStringCellValue方法获取单元格的值,将其赋给一个字符串变量。 8. 输出结果。使用System.out.println方法将获取到的数据打印出来。 需要注意的是,在读取Excel文件时可能会出现FileNotFoundException和IOException异常,需要进行异常处理。同时,在读取完成后,需要关闭输入流。 下面是一个示例代码,用于演示Java使用POI读取Excel文件: ```java import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.IOException; import org.apache.poi.hssf.usermodel.HSSFCell; import org.apache.poi.hssf.usermodel.HSSFRow; import org.apache.poi.hssf.usermodel.HSSFSheet; import org.apache.poi.hssf.usermodel.HSSFWorkbook; public class ExcelReader { public static void poiRead() { FileInputStream xlsStream = null; try { // 创建文件输入流 xlsStream = new FileInputStream(new File("C:\\Users\\itour\\Desktop\\poiTest.xls")); // 创建工作簿对象 HSSFWorkbook hssfWorkbook = new HSSFWorkbook(xlsStream); // 获取工作表 HSSFSheet sheetAt = hssfWorkbook.getSheetAt(0); // 获取行 HSSFRow row = sheetAt.getRow(0); // 获取单元格 HSSFCell cell = row.getCell(0); // 获取单元格的值 String cellValue = cell.getStringCellValue(); System.out.println("获取到的数据是:" + cellValue); } catch (FileNotFoundException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } finally { if (xlsStream != null) { try { xlsStream.close(); } catch (IOException e) { e.printStackTrace(); } } } } } ``` 以上代码演示了如何使用POI库读取Excel文件中第一个工作表的第一个单元格的值。你可以根据自己的需求进行修改和扩展。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值