当前位置:首页 > 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文件的示例代码:

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>

实现数据读取的监听器:

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增加内存分配

异常处理

需处理以下常见异常:

java如何读取excel数据

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

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

相关文章

vue双向实现数据

vue双向实现数据

Vue 双向数据绑定的实现原理 Vue 的双向数据绑定主要通过 v-model 指令实现,其核心是结合了数据劫持(Object.defineProperty 或 Proxy)和发布-订阅模式。以下是具…

如何学习java

如何学习java

学习Java的步骤 理解基础知识 从Java的基本语法开始,包括变量、数据类型、运算符、控制流(if-else、循环)等。掌握这些基础概念是后续学习的基石。 学习面向对象编程(OOP) Java是一…

如何自学java

如何自学java

选择合适的学习资源 从官方文档开始,Oracle提供的Java官方教程(Java Tutorials)是权威且免费的学习资料。在线平台如Codecademy、Coursera或Udemy提供互动式课程…

如何运行java项目

如何运行java项目

运行Java项目的步骤 确保Java环境已安装 在运行Java项目前,需确认系统已安装Java Development Kit(JDK)。通过命令行输入java -version和javac -ver…

java如何创建测试类

java如何创建测试类

创建测试类的基本步骤 在Java中创建测试类通常使用JUnit框架,以下是具体方法: 安装JUnit依赖 对于Maven项目,在pom.xml中添加依赖: <dependency>…

vue 实现查找数据

vue 实现查找数据

Vue 实现查找数据的方法 在 Vue 中实现数据查找功能可以通过多种方式完成,以下是几种常见的方法: 使用计算属性过滤数据 计算属性是 Vue 中响应式处理数据的理想选择,可以根据输入动态过滤数据…