当前位置:首页 > Java

java如何读取excel数据

2026-02-04 22:16:25Java

读取Excel数据的常用方法

在Java中读取Excel数据可以通过多种库实现,以下是两种主流方式:

使用Apache POI库

Apache POI是处理Microsoft Office文件(包括Excel)的常用Java库。需添加以下Maven依赖:

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

读取.xlsx文件的示例代码:

java如何读取excel数据

FileInputStream file = new FileInputStream("data.xlsx");
XSSFWorkbook workbook = new XSSFWorkbook(file);
XSSFSheet sheet = workbook.getSheetAt(0);

Iterator<Row> rowIterator = sheet.iterator();
while (rowIterator.hasNext()) {
    Row row = rowIterator.next();
    Iterator<Cell> cellIterator = row.cellIterator();

    while (cellIterator.hasNext()) {
        Cell cell = cellIterator.next();
        switch (cell.getCellType()) {
            case STRING -> System.out.print(cell.getStringCellValue() + "\t");
            case NUMERIC -> System.out.print(cell.getNumericCellValue() + "\t");
            case BOOLEAN -> System.out.print(cell.getBooleanCellValue() + "\t");
            default -> System.out.print("UNKNOWN\t");
        }
    }
    System.out.println();
}
workbook.close();
file.close();

使用EasyExcel库

EasyExcel是阿里巴巴开发的Excel处理工具,适合大数据量场景,内存占用更低。添加Maven依赖:

<dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>easyexcel</artifactId>
    <version>3.3.2</version>
</dependency>

实现数据读取的监听器:

java如何读取excel数据

public class ExcelDataListener extends AnalysisEventListener<Map<Integer, String>> {
    @Override
    public void invoke(Map<Integer, String> data, AnalysisContext context) {
        System.out.println("解析到一条数据:" + data);
    }

    @Override
    public void doAfterAllAnalysed(AnalysisContext context) {
        System.out.println("所有数据解析完成");
    }
}

调用读取方法:

EasyExcel.read("data.xlsx", new ExcelDataListener()).sheet().doRead();

性能优化建议

对于大文件(超过10万行),推荐使用:

  • POI的SXSSFWorkbook流式API
  • EasyExcel的异步读取模式
  • 设置JVM参数-Xmx1024m增加内存分配

异常处理

需处理以下常见异常:

  • IOException:文件不存在或损坏
  • IllegalStateException:单元格类型不匹配
  • EncryptedDocumentException:加密文件无法读取

标签: 数据java
分享给朋友:

相关文章

java如何创建线程

java如何创建线程

创建线程的方法 在Java中,创建线程主要有两种方式:继承Thread类和实现Runnable接口。以下是具体实现方法: 继承Thread类 通过继承Thread类并重写run()方法可以创建线程。…

java如何创建类

java如何创建类

创建类的基本语法 在Java中,类通过class关键字定义,语法如下: [访问修饰符] class 类名 { // 成员变量(属性) // 构造方法 // 成员方法 }…

java如何生成随机数

java如何生成随机数

生成随机数的方法 在Java中生成随机数可以通过多种方式实现,以下是几种常见的方法: 使用Math.random()方法 Math.random()方法返回一个double类型的伪随机数,范围在[0…

java如何运行程序

java如何运行程序

运行Java程序的步骤 安装Java开发工具包(JDK) 确保系统已安装JDK,可通过命令行输入java -version和javac -version验证。若未安装,需从Oracle官网下载并配置环…

java如何遍历map

java如何遍历map

遍历Map的几种方法 在Java中,遍历Map有多种方式,可以根据需求选择合适的方法。以下是常见的几种遍历方式: 使用entrySet遍历 通过entrySet()方法获取键值对的集合,可以同时访问…

java如何调试

java如何调试

调试Java程序的基本方法 使用IDE内置的调试工具(如IntelliJ IDEA或Eclipse)是最常见的方式。在代码行号旁点击设置断点,启动调试模式后,程序会在断点处暂停,允许查看变量值、调用栈…