推广

springboot+easyExcel实现导出操作

iseeyu2年前 (2024-02-21)推广120

sheet

开始

本项目使用的是springboot + vue +elementUI 实现,由于需要使用导出excel功能,所以浅入了easyExcel模块。

1、导入easyExcel坐标依赖
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>easyexcel</artifactId>
            <version>2.2.6</version>
        </dependency>

easyExcel官方文档:https://www.yuque.com/easyexcel/doc/quickstart

2、实体类编写

在这里使用了lombok插件,使用easyExcel只需要设置导出的excel表列名,使用@ExcelProperty(value=””)注解。具体配置列名、数据转换,日期格式,自定义excel表格样式,请去官网查看。

实体类部分图

3、controller编写
/**
     * 导出档案
     */
    @RequestMapping("/export")
    public void export(@RequestParam Map<String, Object> params, HttpServletResponse response) throws IOException {
        OutputStream outputStream = response.getOutputStream();
        // 获取数据
        PageUtils page = archService.getStatistics(params);
        // 获取农合档案信息
        List<ArchEntity> archEntityList = (List<ArchEntity>) page.getList();
        // 遍历设置List
        if (archEntityList.size() > 0) {
            List<FamilyEntity> familyEntityList = new ArrayList<>();
            List<CardEntity> cardEntityList = new ArrayList<>();
            List<PayEntity> payEntityList = new ArrayList<>();
            for (int i = 0; i < archEntityList.size(); i++) {
                // 获取家庭档案
                familyEntityList.add(i, archEntityList.get(i).getFamilyEntity());
                // 获取慢性病卡档案
                cardEntityList.add(i, archEntityList.get(i).getCardEntity());
                // 获取慢性病报销信息
                payEntityList.add(i, archEntityList.get(i).getPayEntity());
            }
            try {
                // 设置response
                response.setContentType("application/vnd.ms-excel");
                response.setCharacterEncoding("utf-8");
                // 这里URLEncoder.encode可以防止中文乱码 当然和easyexcel没有关系
                String fileName = URLEncoder.encode("统计信息", "UTF-8");
                response.setHeader("Content-disposition", "attachment;filename=" + fileName + ".xlsx");
                //新建ExcelWriter
                ExcelWriter excelWriter = EasyExcel.write(outputStream).build();
                //获取archSheet对象
                WriteSheet archSheet = EasyExcel.writerSheet(0, "农合信息档案").head(ArchEntity.class).build();
                //获取参合人员信息,向archSheet写入数据
                excelWriter.write(archEntityList, archSheet);
                //获取archSheet对象
                WriteSheet familySheet = EasyExcel.writerSheet(1, "参合家庭档案").head(FamilyEntity.class).build();
                //获取家庭参合信息,向familySheet写入数据
                excelWriter.write(familyEntityList, familySheet);
                //获取cardSheet对象
                WriteSheet cardSheet = EasyExcel.writerSheet(2, "慢性病卡信息").head(CardEntity.class).build();
                //获取家庭参合信息,向cardSheett写入数据
                excelWriter.write(cardEntityList, cardSheet);
                //获取paySheet对象
                WriteSheet paySheet = EasyExcel.writerSheet(3, "报销记录").head(PayEntity.class).build();
                //获取家庭参合信息,向paySheet写入数据
                excelWriter.write(payEntityList, paySheet);
                //关闭流
                excelWriter.finish();
                outputStream.flush();
            } catch (IOException e) {
                log.error("导出异常{}", e.getMessage());
            }
        }
    }
  • 1、创建OutputStream对象
OutputStream outputStream = response.getOutputStream();
  • 2、设置头、类型、编码格式
// 设置response
response.setContentType("application/vnd.ms-excel");
response.setCharacterEncoding("utf-8");
// 这里URLEncoder.encode可以防止中文乱码 当然和easyexcel没有关系
String fileName = URLEncoder.encode("统计信息", "UTF-8");
response.setHeader("Content-disposition", "attachment;filename=" + fileName + ".xlsx");
  • 3、创建ExcelWriter对象
//新建ExcelWriter
ExcelWriter excelWriter = EasyExcel.write(outputStream).build();
  • 4、创建WriteSheet对象,调用EasyExcel.writerSheet()方法写入参数
//获取archSheet对象
WriteSheet archSheet = EasyExcel.writerSheet(0, "农合信息档案").head(ArchEntity.class).build();

0为第一个模板(sheet),名称是农合信息档案。head()中传入的参数为实体类

  • 5、调用excelWriter.write()向sheet模板写入参数
//获取参合人员信息,向archSheet写入数据
excelWriter.write(archEntityList, archSheet);

向excelWriter.write()方法中传入List数据与WriteSheet对象

  • 6、关闭excelWriter.finish()
//关闭流
excelWriter.finish();
  • 7 、关闭outputStream.flush();
 outputStream.flush();
3、前端界面编写
// 导出档案
    exportHandle () {
      this.$nextTick(() => {
        this.$http({
          url: this.$http.adornUrl('/mxbbx/arch/export'),
          method: 'get',
          responseType: 'blob',
          params: this.$http.adornParams({
            'page': this.pageIndex,
            'limit': this.pageSize,
            'groupId': this.dataForm.groupId,
            'apName': this.dataForm.apName,
            'areaTime': this.dataForm.areaTime,
            'drName': this.dataForm.drName
          })
        }).then(({data}) => {
          // 创建Blob对象
          let blob = new Blob([data], { type: 'application/vnd.ms-excel;charset=utf-8' })
          // 获取路径
          let url = window.URL.createObjectURL(blob)
          // 创建a标签
          const link = document.createElement('a')
          // 设置a标签链接参数
          link.href = url
          // 重命名文件
          link.download = '报销信息.xlsx'
          link.click()
          // 下载完成释放URL 对象
          URL.revokeObjectURL(url)
          // 移除a标签
          document.body.removeChild(link)
        })
      })
    },

注意事项
1、这里我使用的axios异步调用处理(和ajax没啥大区别)
2、请求参数中设置:responseType: ‘blob’,将返回响应类型设置为blob
3、在返回成功then()中,创建a标签,并为a标签设置超链接,并设置点击下载文件流。如果不使用创建a标签的方式,将不会显示下载弹窗!!!(大坑,后端成功了,前端一直没有出现下载文件的弹窗,可能是vue的原因,在html中无需设置)

扫描二维码推送至手机访问。

版权声明:本文由西安泽虎代运营发布,如需转载请注明出处。

转载请注明出处https://www.0291.com.cn/post/57557.html

相关文章

淘宝店铺推广词怎么写(淘宝店铺广告怎么做)

淘宝店铺推广词怎么写(淘宝店铺广告怎么做)

再来就是双关型的所谓的双关就是一语双关,既要说出产品类型和特色又要别有深意,给人想象的空间,一般的话,个人想象其实是最好的,因为人们总是趋向于美化产品。...

整合营销怎么做效果最大化

整合营销怎么做效果最大化

整合怎么做效果最大化...

这些方面没利用好会影响排名。

这些方面没利用好会影响排名。

发外链是快速提升网站排名的一种方法之一,持续稳定的更新外链,可以增加网站的权重,有利于网站的排名提升,当然操作要得当,不然会损失惨重。 内容质量也是搜索引擎最看重的地方,搜索引擎喜欢抓取高质量的内容,平常在写文章的时候最好不要复制帖粘,内容的原创性这方面是搜索引擎对网站质量的衡量标准...

淘宝联盟量无忧有什么功能

淘宝联盟量无忧有什么功能

稳定流量:除站外淘宝客社群流量、采买流量和联盟官方流量域这三大流量域外,手淘站内针对报名量无忧活动的商品会有对应行业营销资源包的流量扶持,四大流量场景共同提供稳定性流量补给。...

如何开网站呢(想开个网站怎样开)

如何开网站呢(想开个网站怎样开)

无论是企业还是个人想要做网站,申请域名、搭建网页是第一步,做好之后,想要让用户在百度搜索引擎找到你的网站,就需要进行第二步骤的操作了,设置TDK,推送网站网址给百度,搞定百度收录,对不懂技术的朋友来说,直接通过第三方一站式服务平台,就能轻松完美搞定以上全部操作,接下来我来演示在乔拓云网如何做到以...

一条抖音捧火一个品牌!如何利用信息流实现野蛮生长?

一条抖音捧火一个品牌!如何利用信息流实现野蛮生长?

成长往往很痛苦,但聪明的学习可以让你很快乐。 信息流的热度居高不下,且已经逐渐成为广告主们的主流推广方式。同时,它的转化效果也不容小觑。 比如抖音,一个小小的短视频,可谓是捧火了众多品牌,像小猪佩奇、海底捞网红搭配等等。 虽然信息流很火,也是未来主流推广方式。可仍有不少优化师对信息流...

现在,非常期待与您的又一次邂逅

我们努力让每一部企业宣传片和抖音短视频成为商业大片