当前位置:首页 > Java

java如何导出excel

2026-03-03 09:58:07Java

使用 Apache POI 库导出 Excel

Apache POI 是 Java 操作 Microsoft Office 文档的流行库,支持 Excel 的读写操作。

确保项目中已添加 Apache POI 依赖:

<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>

创建 Workbook 对象并写入数据:

Workbook workbook = new XSSFWorkbook(); // 创建 HSSFWorkbook 用于 .xls 格式
Sheet sheet = workbook.createSheet("Sheet1");

// 创建表头
Row headerRow = sheet.createRow(0);
headerRow.createCell(0).setCellValue("姓名");
headerRow.createCell(1).setCellValue("年龄");

// 写入数据
Row dataRow = sheet.createRow(1);
dataRow.createCell(0).setCellValue("张三");
dataRow.createCell(1).setCellValue(25);

// 导出文件
try (FileOutputStream fos = new FileOutputStream("output.xlsx")) {
    workbook.write(fos);
} catch (IOException e) {
    e.printStackTrace();
} finally {
    workbook.close();
}

使用 EasyExcel 导出 Excel

EasyExcel 是阿里巴巴开源的 Excel 操作工具,适合大数据量导出,内存占用低。

添加 EasyExcel 依赖:

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

定义数据模型类:

@Data
public class UserData {
    @ExcelProperty("姓名")
    private String name;

    @ExcelProperty("年龄")
    private Integer age;
}

执行导出操作:

List<UserData> dataList = Arrays.asList(
    new UserData("张三", 25),
    new UserData("李四", 30)
);

String fileName = "output.xlsx";
EasyExcel.write(fileName, UserData.class)
         .sheet("用户数据")
         .doWrite(dataList);

使用 JExcelAPI 导出 Excel

JExcelAPI 是另一个轻量级 Excel 操作库,适合处理 .xls 格式。

添加 JExcelAPI 依赖:

<dependency>
    <groupId>net.sourceforge.jexcelapi</groupId>
    <artifactId>jxl</artifactId>
    <version>2.6.12</version>
</dependency>

导出代码示例:

WritableWorkbook workbook = Workbook.createWorkbook(new File("output.xls"));
WritableSheet sheet = workbook.createSheet("Sheet1", 0);

// 添加表头
Label label1 = new Label(0, 0, "姓名");
Label label2 = new Label(1, 0, "年龄");
sheet.addCell(label1);
sheet.addCell(label2);

// 添加数据
Label nameLabel = new Label(0, 1, "张三");
Label ageLabel = new Label(1, 1, "25");
sheet.addCell(nameLabel);
sheet.addCell(ageLabel);

workbook.write();
workbook.close();

导出 Excel 到 HTTP 响应

在 Web 应用中直接导出 Excel 到浏览器响应:

@GetMapping("/export")
public void exportExcel(HttpServletResponse response) throws IOException {
    response.setContentType("application/vnd.ms-excel");
    response.setHeader("Content-Disposition", "attachment;filename=output.xlsx");

    Workbook workbook = new XSSFWorkbook();
    Sheet sheet = workbook.createSheet("Sheet1");

    // 写入数据...

    workbook.write(response.getOutputStream());
    workbook.close();
}

处理大数据量导出

对于大数据量导出,建议采用分批处理方式:

// 使用 SXSSFWorkbook 优化内存
Workbook workbook = new SXSSFWorkbook(100); // 保留100行在内存中
Sheet sheet = workbook.createSheet("大数据");

// 分批查询数据并写入
int batchSize = 1000;
int rowNum = 0;
while (hasMoreData()) {
    List<Data> batchData = fetchData(batchSize);
    for (Data data : batchData) {
        Row row = sheet.createRow(rowNum++);
        // 填充数据...
    }
}

// 导出...

每种方法适用于不同场景,Apache POI 功能最全面,EasyExcel 适合大数据量,JExcelAPI 适合旧格式。根据项目需求选择合适方案。

java如何导出excel

标签: javaexcel
分享给朋友:

相关文章

java如何创建文件

java如何创建文件

使用 File 类创建文件 通过 File 类的 createNewFile() 方法创建文件。此方法返回布尔值,表示文件是否成功创建。 import java.io.File; import ja…

java如何创建线程

java如何创建线程

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

java如何

java如何

Java 基础语法 Java 是一种面向对象的编程语言,语法相对严谨。每个 Java 程序必须包含一个 main 方法作为程序入口。以下是一个简单的 Java 程序示例: public class…

如何用java

如何用java

用Java实现基础功能 Java是一种广泛使用的编程语言,适用于开发各种应用程序。以下是几个常见功能的实现方法。 打印"Hello, World!" public class HelloWorld…

java如何调用方法

java如何调用方法

调用方法的基本语法 在Java中,调用方法需要明确方法所属的对象(实例方法)或类(静态方法),并传递必要的参数。语法格式如下: 实例方法:对象名.方法名(参数列表); 静态方法:类名.方法…

如何学好java

如何学好java

理解基础概念 掌握Java的核心概念是学习的基础。包括数据类型、变量、运算符、控制流(如循环和条件语句)、数组等。理解面向对象编程(OOP)的四大特性:封装、继承、多态和抽象。 实践编程练习 通过实…