实现excel导出最简单方式

今天来记录一下导出excel的实现方式,导出的格式是xlsx的文件。

这里用到的是hutool的工具包,依赖如下:

复制代码
<dependency>
    <groupId>cn.hutool</groupId>
    <artifactId>hutool-all</artifactId>
    <version>5.3.5</version>
    <scope>compile</scope>
</dependency>
复制代码
<!--读取excel组件-->
<dependency>
    <groupId>org.apache.poi</groupId>
    <artifactId>poi-ooxml</artifactId>
    <version>4.1.2</version>
</dependency>

导出代码如下:

java 复制代码
    @PostMapping(value = "download", consumes = APPLICATION_JSON_VALUE)
    public void download(@RequestBody QaLogPageVO pageVO, HttpServletResponse response) throws IOException {
        List<QaLog> list = service.list();

        ExcelWriter writer = ExcelUtil.getWriter(true);
        //自定义标题别名
        writer.addHeaderAlias("name", "姓名");
        writer.addHeaderAlias("time", "提问时间");
        writer.addHeaderAlias("model", "模型");
        writer.addHeaderAlias("question", "问题");
        writer.addHeaderAlias("answer", "答案");
        writer.addHeaderAlias("source", "来源");
        writer.addHeaderAlias("feedbackStatus", "反馈");
        writer.addHeaderAlias("department", "部门");

        // 默认的,未添加alias的属性也会写出,如果想只写出加了别名的字段,可以调用此方法排除之
        writer.setOnlyAlias(true);

        String title = DateUtil.format(startTime,"yyyy-MM-dd HH:mm:ss") +"------"+ DateUtil.format(endTime,"yyyy-MM-dd HH:mm:ss");
        // 合并单元格后的标题行,使用默认标题样式
        writer.merge(7, title);
        // 一次性写出内容,使用默认样式,强制输出标题
        writer.write(list, true);

        response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;charset=utf-8");
        response.setHeader("Content-Disposition", "attachment;filename=test.xlsx");
        ServletOutputStream out = response.getOutputStream();

        writer.flush(out, true);
        writer.close();
        IoUtil.close(out);
    }
相关推荐
云飞云共享云桌面4 分钟前
8-10位研发3D(sw、ug、creo)画图如何共享一台工作站?
运维·服务器·网络·数据库·3d·电脑
x***r1515 分钟前
Wise Care 365 优化工具安装教程:安装+系统优化工具
windows
stereohomology11 分钟前
【折腾】windows下小狼毫输入法更新字库
windows·rime·输入法·小狼毫
三道渊19 分钟前
Linux进程通信与信号处理全解析
linux·服务器·网络
AI_Claude_code22 分钟前
ZLibrary访问困境方案六:自建RSS/Calibre内容同步服务器的完整指南
运维·服务器·网络·爬虫·python·tcp/ip·http
Java后端的Ai之路22 分钟前
sudo 命令详解:Linux 权限管理的“万能钥匙“
linux·运维·服务器·sudo
ID_1800790547324 分钟前
Python解析小红书(XHS)笔记评论 API,json数据返回参考
java·服务器·数据库
mhkxbq32 分钟前
昆仑G5580、G5680 V2、G2280及泰山鲲鹏200,AI大数据优选服务器
大数据·服务器·人工智能
艾莉丝努力练剑40 分钟前
【QT】Qt常用控件与布局管理深度解析:从原理到实践的架构思考
linux·运维·服务器·开发语言·网络·qt·架构
idolao41 分钟前
图吧工具箱2024安装教程:详细步骤+自定义路径(64位)
windows