EasyExcel导出本地文件

这篇博客介绍了如何在Java中使用EasyExcel库来快速导出数据到Excel文件。通过引入阿里巴巴的EasyExcel依赖,创建一个工具类并定义数据模型,实现了简单的数据写入操作。示例代码展示了如何创建一个包含姓名和年龄字段的Person类,然后将数据列表写入到Excel文件。
摘要由CSDN通过智能技术生成

1.引入依赖

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

2. 工具类

import com.alibaba.excel.EasyExcel;

import java.util.List;

public class TestFileUtil {
    public static void downExcel(Class clz, List<?> list) {
        String fileName = TestFileUtil.class.getResource("/").getPath() + "simpleWrite" + System.currentTimeMillis() + ".xlsx";
        EasyExcel.write(fileName, clz).sheet("模板").doWrite(list);
    }
}

3. 调用

public class ExportTest {
    @Data
    @AllArgsConstructor
    public static class Person {
        @ExcelProperty(value = "姓名", index = 0)
        private String name;

        @ExcelProperty(value = "年龄", index = 1)
        private String age;
    }

    public static void main(String[] args) {
        List<Person> list = new LinkedList<>();
        Person a = new Person("Tom", "12");
        list.add(a);
        TestFileUtil.downExcel(Person.class, list);
    }
}
EasyExcel是一个基于Java的Excel操作工具,支持读取、写入、复制、合并、样式设置等操作,同时支持大数据量的读写和导出。 如果要使用EasyExcel导出文件到本地,可以按照以下步骤进行操作: 1. 添加依赖:在pom.xml中添加EasyExcel的依赖: ```xml <dependency> <groupId>com.alibaba</groupId> <artifactId>easyexcel</artifactId> <version>2.2.6</version> </dependency> ``` 2. 创建Excel文件:使用EasyExcel提供的注解标记数据模型,并创建ExcelWriter对象,指定输出文件路径。 ```java // 1. 创建输出流 OutputStream out = new FileOutputStream("output.xlsx"); // 2. 创建 ExcelWriter 对象 ExcelWriter writer = new ExcelWriter(out, ExcelTypeEnum.XLSX); // 3. 构造要写入的数据 List<DemoData> dataList = new ArrayList<>(); dataList.add(new DemoData("张三", 18)); dataList.add(new DemoData("李四", 20)); // 4. 指定 Sheet 名称 Sheet sheet1 = new Sheet(1, 0, DemoData.class); sheet1.setSheetName("第一个Sheet"); // 5. 写入数据 writer.write(dataList, sheet1); // 6. 关闭资源 writer.finish(); out.close(); ``` 3. 下载Excel文件:通过Java的文件IO操作,将Excel文件下载到本地。 ```java // 1. 打开文件流 InputStream inputStream = new FileInputStream("output.xlsx"); // 2. 设置响应头 response.setContentType("application/octet-stream"); response.setHeader("Content-disposition", "attachment;filename=output.xlsx"); // 3. 下载文件到本地 ServletOutputStream outputStream = response.getOutputStream(); byte[] bytes = new byte[1024]; int len; while ((len = inputStream.read(bytes)) != -1) { outputStream.write(bytes, 0, len); } outputStream.close(); inputStream.close(); ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值