在线问题反馈模块实战(十九):实现数据批量导出到excel文件中功能

举报
bug菌 发表于 2023/06/16 15:25:05 2023/06/16
【摘要】 我是bug菌,一名想走👣出大山改变命运的程序猿。接下来的路还很长,都等待着我们去突破、去挑战。来吧,小伙伴们,我们一起加油!未来皆可期,fighting!

👨‍🎓作者:bug菌
✏️博客:CSDN掘金infoQ51CTO
🎉简介:CSDN/阿里云/华为云/51CTO 博客专家,博客之星Top30,掘金年度人气作者Top40,51CTO年度博主Top12,掘金/InfoQ/51CTO等社区优质创作者,全网粉丝合计10w+,硬核微信公众号猿圈奇妙屋」,欢迎你的加入!免费领取简历模板/学习资料/大厂面试真题/职业规划等海量资料。
..
✍️温馨提醒:本文字数:1999字, 阅读完需:约 6 分钟

        嗨,家人们,我是bug菌呀,我又来啦。今天我们来聊点什么咧,OK,接着为大家更《springboot零基础入门教学》系列文章吧。希望能帮助更多的初学者们快速入门!

        如果小伙伴们在批阅文章的过程中觉得文章对自己有帮助,请别吝啬手中的赞呀,大胆的把文章点亮👍,相信你点赞了好的文章,平台也会经常给你推荐高质量好文,您的点赞三连(收藏+关注+留言)就是对bug菌写文道路上最好的鼓励与支持😘。时光不弃🏃🏻‍♀️,创作不停💕,加油☘️

一、前言🔥

       接下来的这几期,bug菌想跟大家分享一下自己昨天刚接到一个临时的需求,热乎着呢,想分享一下自己是如何面对临时需求并制定整个开发周期,其中包括从梳理业务到创建业务表再到实现业务逻辑形成闭环再到与前端对接,其中会穿插一些业务拓展及功能性拓展,这一条龙流程在线与大家一起见证,分享给刚入门的小伙伴,希望对你们有所帮助。

环境说明:idea2019.3 + springboot2.3.1.REALSE + mybati-plus3.2.0 + mysql5.6 + jdk1.8

       若小伙伴们在批阅文章的过程中觉得文章对您有一丝丝帮助,还请别吝啬您手里的赞呀,大胆的把文章点亮👍吧,您的点赞三连(收藏⭐️+关注👨‍🎓+留言📃)就是对bug菌我创作道路上最好的鼓励与支持😘。时光不弃🏃🏻‍♀️,创作不停💕,加油☘️ 

二、正文🔥

         对于上几期而言,我们后面将近15篇都是干货级教学文章,写的都是对于具体业务场景, 如何通过接口的形式去实现,这也是你们在未来业务中经常需要涉及的东西,既然前后端分离,那肯定都是需要数据就得提供接口,通过请求接口获取数据,页面通过接口返回的数据进行渲染,这就是形成了一个闭环,而这一期呢?我给大家带来点什么呢?你们猜猜。

        本期其实内容也很简单,做的内容是对于上两期excel文件类型业务形成一个闭环,业务支持文件导入,自然就支持文件导出,所以这一期的内容相对而言,还是一起excel文件如何实现导出的功能教程。

        那么,废话不多说,咱们直接整活儿吧!

三、如何代码实现分页查询功能🔥

0️⃣ 引入依赖

        对于excel的导入导出功能,我们这里用到的是easypoi的开源组件,也推荐大家使用。使用起来简单且易上手,上一期我们也是通过它提供的导入方法实现excel文件的导入读取,现在要实现excel文件的导出,人家依旧有提供对于的方法。

        so,只需要在你们的pom依赖配置文件中加上如下依赖配置即可,若是已经引入的小伙伴可以直接跳过此步骤。

        <!--easypoi依赖,excel导入导出-->
        <dependency>
            <groupId>cn.afterturn</groupId>
            <artifactId>easypoi-spring-boot-starter</artifactId>
            <version>4.3.0</version>
        </dependency>

1️⃣定义Controller请求

        面临第一步,就是确定接口请求格式,如果你对于返回值没有固定概念,你们可以先不确定,最后根据具体方法返回什么再定返回类型即可。我是直接不需要返回值,毕竟导出,成功就是文件直接下载,还需要啥返回值呢,对吧。

如下是我所定义的接口请求,仅供参考:

    /**
     * excel批量导出问题反馈
     */
    @GetMapping("/export")
    @ApiOperation(value = "excel批量用户导出", notes = "excel批量用户导出")
    public void export(HttpServletResponse response) {
        userQuestionsService.exportQuestions(response);
    }

2️⃣定义接口方法exportQuestions()

        既然无返回值,直接void即可。

    /**
     * excel批量导出问题反馈
     */
    void exportQuestions(HttpServletResponse response);

3️⃣重写exportQuestions()方法

        重写exportQuestions()方法,目的就是把核心逻辑写进去。而正确对于excel文件的导入,我分为两步来写,第一步,获取需要导出的数据集,第二步调用导出方法将数据集写入到文件流中。

具体如何实现?请看我如下代码实现逻辑:

    /**
     * excel批量导出问题反馈
     */
    @Override
    public void exportQuestions(HttpServletResponse response) {

        try {
            //从数据库查询所有除删除外的数据
            LambdaQueryWrapper<UserQuestionsEntity> wrapper = new LambdaQueryWrapper<>();
            wrapper.ne(UserQuestionsEntity::getStatus,2);
            wrapper.orderByDesc(UserQuestionsEntity::getCreateTime);
            List<UserQuestionsEntity> questions = this.list(wrapper).subList(0,3);//只取3条数据。

            //设置信息头,告诉浏览器内容为excel类型
            response.setHeader("content-Type", "application/vnd.ms-excel");
            //设置下载名称
            response.setHeader("Content-Disposition", "attachment;filename=" + URLEncoder.encode("所有用户问题反馈导出报表.xls", StandardCharsets.UTF_8.name()));
            //字节流输出
            ServletOutputStream out = response.getOutputStream();
            //设置excel参数
            ExportParams params = new ExportParams();
            //设置sheet名名称
            params.setSheetName("问题反馈列表");
            //设置标题
            params.setTitle("所有用户问题反馈列表");

            //转成对应的类型;要不然会报错,虽然也可以导出成功
            List<ExportQuestions> exportUsers = this.changeType(questions);
            //导入excel
            Workbook workbook = ExcelExportUtil.exportExcel(params, ExportQuestions.class, exportUsers);
            //写入
            workbook.write(out);
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

         注意一下:我是由于项目是本公司未开源项目,其中数据都为测试所用,所以至此我是对查询数据集做了一个筛选,按创建时间倒序排列且取了前三条,为什么是前三条,这不就是我们上午刚导入的这三条数据嘛,也正是由于给大家演示的数据,所以不怕涉密,这你们能理解吧。所以对于结果集你们应该是传入你们想导出展示的数据集即可。

        然后就是指定文件名、文件内标题、文件sheet名等自定义好。还有对于changeType()方法,目的是为了做pojo转写,将实体转成对于的导出类pojo,比如我上文所涉及的QuestionsEntity 转成ExportQuestions。

具体转写如下:

    /**
     * 转成导出vo
     */
    private List<ExportQuestions> changeType(List<UserQuestionsEntity> questions) {
        List<ExportQuestions> res = new ArrayList<>();
        for (UserQuestionsEntity question : questions) {
            ExportQuestions exportUser = new ExportQuestions(question);
            res.add(exportUser);
        }
        return res;
    }

        至此,导出接口请求就定义好了。我们直接走接口测试,查验下接口是否有报错情况。项目先重启一下。

4️⃣接口测试

        这里我由于是添加了token拦截认证,所以我还是将该请求接口方法挪到了common模块下。这样我就不需要请求时携带token请求头了,你们具体情况具体看待,因为想用浏览器模拟请求,设置请求的header就没啥办法了。

        输入定义好的请求地址,然后直接在浏览器上,回车,你们可以看到,会弹出一个下载框,那就是浏览器在帮你将执行导出方法所致。

        对于导出的excel文件,我们可以看下,文件名,标题名,sheet名及记录内容,是否都与你查询出的内容一致?你都可以从数据上,代码上一一校验,好吧。

        如上导出,控制台并无报错哦,所以对于需要的小伙伴们,可以放心拿去参考了,你们要改的也就是其导出记录,然后指定的文件名及标题名等自定义内容,其他的都可以照搬照抄,都给大家测试好了,放心吧。

5️⃣总结

        对于越简单的逻辑接口而言,我们都要百分百用心写。

... ...

        好啦,以上就是这期的所有内容啦,你们学废了么?如果对你有所帮助,还请不要忘记给bug菌[三连支持]哟。如果想获得更多的学习资源或者想和更多的技术爱好者一起交流,可以关注我的公众号『猿圈奇妙屋』,后台回复关键词领取学习资料、大厂面经、面试模板等海量资源,就等你来拿。

四、往期热文推荐🔥

        对于问题反馈模块实战开发,我完整的梳理了每一期的教学及链接地址,仅供参考:希望能对你们有所帮助。

        如上是整整二十期内容,每一期都是干货,对于一个模块的开发,如何一点一滴打造并测试部署上线,我再说一遍,这不是演习,是实战!是实战!是实战!

        若你们觉得只是需要了解其中某个知识点或者业务的话,也不反对,你就选择其中的几期进行学习就好,反正都已经完结啦;我只希望你们能有所收获,有所成长,也就不枉我苦心每天下班后给大家总结更新。

五、文末🔥

        如果还想要学习更多,小伙伴们直接订阅bug菌专门为大家创建的零基础入门Spring Boot专栏《滚雪球学Spring Boot》,从无到有,从零到一!以知识点+实例+项目的学习模式由浅入深对Spring Boot框架进行学习&使用。

       我是bug菌,一名想走👣出大山改变命运的程序猿。接下来的路还很长,都等待着我们去突破、去挑战。来吧,小伙伴们,我们一起加油!未来皆可期,fighting!

【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。