当前位置:首页 > 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();
}

处理大数据量导出

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

java如何导出excel

// 使用 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 适合旧格式。根据项目需求选择合适方案。

标签: javaexcel
分享给朋友:

相关文章

如何安装java环境

如何安装java环境

下载JDK安装包 访问Oracle官方网站或OpenJDK项目页面,选择适合操作系统的JDK版本(如Windows、macOS或Linux)。确保下载与系统架构匹配的版本(32位或64位)。 运行安…

java如何生成随机数

java如何生成随机数

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

java版本如何查看

java版本如何查看

查看Java版本的命令行方法 在命令行或终端中运行以下命令可以查看当前安装的Java版本: java -version 输出示例: java version "1.8.0_301" Java(TM…

如何启用java

如何启用java

启用 Java 的方法 检查 Java 是否已安装 在命令行或终端输入 java -version,如果显示版本信息,说明 Java 已安装。若未安装,需从 Oracle 官网 或 OpenJDK 下…

java 实现 php ord

java 实现 php ord

Java 实现 PHP 的 ord 函数 PHP 的 ord 函数用于获取字符串中第一个字符的 ASCII 值。在 Java 中,可以通过类型转换或直接使用字符的 Unicode 值实现类似功能。…

PHP实现excel

PHP实现excel

PHP 实现 Excel 操作 读取 Excel 文件 使用 PHP 读取 Excel 文件可以通过 PhpSpreadsheet 库实现。安装该库可以通过 Composer: composer r…