java导出Excel

文章展示了如何在SpringBoot应用中结合EasyExcel库来导出数据到Excel文件。它使用MyBatisPlus进行数据库操作,Lombok简化实体类,通过控制器函数生成并下载Excel文件。
摘要由CSDN通过智能技术生成

依赖

 <dependencies>
        <!--  EasyExcel-->
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>easyexcel</artifactId>
            <version>2.0.5</version>
        </dependency>
        <!-- MyBatisPlus -->
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-boot-starter</artifactId>
            <version>3.4.2</version>
        </dependency>
        <!--lombok-->
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <optional>true</optional>
        </dependency>
        <!--springMVC-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <!--springBoot起步依赖-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter</artifactId>
        </dependency>
        <!--test-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>

实验室Excel实体类

/**
 * 实验室Excel实体类
 */
@Data
public class LabExcel {
    @TableId
    @ExcelProperty("id")
    private Integer labId;
    @ExcelProperty("实验室")
    private String labName;//实验室
    @ExcelProperty("地址")
    private String labAddress;//地址
    @ExcelProperty("负责人")
    private String labPerson;//负责人
    @ExcelProperty("联系电话")
    private String labPhone;//联系电话
    @ExcelProperty("开放时间段")
    private String labOpen;//开放时间段

}

导出excel控制器

 /**
     * 导出excel
     * @param response
     * @throws IOException
     */
    @GetMapping("/excel")
    @ResponseBody
    public void test(HttpServletResponse response) throws IOException {
        List<LabExcel> list=new ArrayList<>();
        List<Lab> labList = labService.search(1, 10).getRecords();
        for (Lab lab:labList) {
            LabExcel labExcel=new LabExcel();
            labExcel.setLabId(lab.getLabId());
            labExcel.setLabName(lab.getLabName());
            labExcel.setLabAddress(lab.getLabAddress());
            labExcel.setLabPerson(lab.getLabPerson());
            labExcel.setLabPhone(lab.getLabPhone());
            labExcel.setLabOpen(lab.getLabOpen());
            list.add(labExcel);
        }
        response.setContentType("application/vnd.ms-excel");
        response.setHeader("Content-Disposition","attachment;filename="+"LabDetail.xlsx");
        ExcelWriter excelWriter= EasyExcel.write(response.getOutputStream()).build();
        //定义工作表对象
        WriteSheet sheet = EasyExcel.writerSheet(0, "sheet").head(LabExcel.class).build();
        //往excel文件中写入数据
        excelWriter.write(list,sheet);
        excelWriter.finish();
    }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

月木@

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值