Java根据模板实现excel导出标准化

 更新时间:2024年03月05日 16:22:03   作者:warrah  
这篇文章主要为大家详细介绍了Java如何根据模板实现excel导出标准化,文中的示例代码讲解详细,具有一定的借鉴价值,有需要的小伙伴可以参考下

虽然标题叫标准化,只不过是我自己的习惯,当一件事情变得流程标准化之后,开发程序就会飞快,开发评估工作总是 搞个1~2天,实则前端后端一起开发,1个小时就可以搞定。

前端

const exportXls = async () => {
    var now = moment(new Date()).format('YYYYMMDDHHMMSS')
    let name = '商品收发明细表.xls'
    const res = await proxy.$api.invOrder.goodsRdDetail.export({...condForm.value})
    let data = res.data;
    let url = window.URL.createObjectURL(new Blob([data], ))
    let link = document.createElement('a')
    link.style.display = 'none'
    link.href = url;
    console.log(link);
    link.setAttribute('download', now + name)
    document.body.appendChild(link)
    link.click()
    document.body.removeChild(link)
}

请求的代码如下

public postOnlyFile = (url: string, data = {} , config: AxiosRequestConfig<any> = {}): Promise<any> =>
    axios({
        ...this.baseConfig,
        headers:{
            ...this.baseConfig.headers,
            'Content-Type': "application/json"
        },
        responseType:'blob',
        url,
        method: 'post',
        data,
        ...config,
    })

后端

controller层基本就是复制粘贴,传参数给到service层而已。

    @PostMapping("export")
    @ApiOperation("导出商品收发明细表")
    public void export(@RequestBody PsiInvOrderReportCondDto condDto, HttpServletResponse response){
        //设置响应头
        response.setContentType("application/vnd.ms-excel");
        response.setCharacterEncoding("utf-8");
        //设置防止文件名中文乱码
        try {
            //设置防止文件名中文乱码
            String fileName = URLEncoder.encode("商品收发明细表", "utf-8");
            response.setHeader("Content-disposition", "attachment;filename=" + fileName + ".xlsx");
            //
            if (!CheckEmptyUtil.isEmpty(condDto.getBillDateRange())){
                condDto.setStartBillDate(condDto.getBillDateRange().get(0));
                condDto.setEndBillDate(condDto.getBillDateRange().get(1));
            }
            goodsRdDetailService.export(response.getOutputStream(),"xls/GoodsRdDetail.xls", condDto);
        } catch (Exception e) {
            log.error(e.getMessage(), e);
        }
    }

service层主要通过easyexcel填充数据

import com.alibaba.excel.EasyExcel;
import com.alibaba.excel.ExcelWriter;
import com.alibaba.excel.write.metadata.WriteSheet;
import com.alibaba.excel.write.metadata.fill.FillConfig;
    @Override
    public void export(OutputStream outputStream, String pathName, PsiInvOrderReportCondDto condDto) {
        List<GoodsRdDetailListDto> goodsRdDetailListDtos = select(condDto);
        int line = 1;
        for (GoodsRdDetailListDto goodsRdDetailListDto:goodsRdDetailListDtos){
            goodsRdDetailListDto.setLine(String.valueOf(line++));
            goodsRdDetailListDto.setBillDateStr(DateUtil.formatDate(goodsRdDetailListDto.getBillDate()));
            BusinessTypeEnum businessTypeEnum = BusinessTypeEnum.getInvBusinessTypeEnum(goodsRdDetailListDto.getBusiType());
            goodsRdDetailListDto.setBusiType(businessTypeEnum.display());
        }
        org.springframework.core.io.Resource resource = new ClassPathResource(pathName);
        InputStream inputStream = null;
        String fileName = DateUtil.getDateRandom() + ".xls";
        File file = new File(TmpDic.url + File.separator + fileName);
        try {
            inputStream = resource.getInputStream();
            FileUtils.copyInputStreamToFile(inputStream, file);
        } catch (IOException e) {
            e.printStackTrace();
        }
        ExcelWriter excelWriter = EasyExcel.write(outputStream).withTemplate(file).build();
        FillConfig fillConfig = FillConfig.builder().forceNewRow(Boolean.TRUE).build();
        //
        WriteSheet sheet0 = EasyExcel.writerSheet(0,"单据明细(不合并表头)")
                //单元格
//                .registerWriteHandler(new CustomCellWriteHandler())
                .build();
        excelWriter.fill(goodsRdDetailListDtos, fillConfig, sheet0);
        //
        PsiAccountSet psiAccountSet = psiAccountSetService.getById(condDto.getAsId());
        GoodsRdDetailExcelHeaderDto excelHeaderDto = new GoodsRdDetailExcelHeaderDto();
        excelHeaderDto.setCompanyName(psiAccountSet.getName());
        excelHeaderDto.setStartBillDate(DateUtil.formatDate(condDto.getStartBillDate()));
        excelHeaderDto.setEndBillDate(DateUtil.formatDate(condDto.getEndBillDate()));
        excelWriter.fill(excelHeaderDto,sheet0);
        //
        excelWriter.finish();
        file.delete();
    }

excel模板

定义excel模板,就是上面的xls/GoodsRdDetail.xls

到此这篇关于Java根据模板实现excel导出标准化的文章就介绍到这了,更多相关Java导出excel内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • JAVA中Object的常用方法

    JAVA中Object的常用方法

    JAVA中Object是所有对象的顶级父类,存在于java.lang包中,这个包不需要我们手动导包,本文通过实例代码介绍JAVA中Object的常用方法,感兴趣的朋友一起看看吧
    2023-11-11
  • SpringBoot环境下junit单元测试速度优化方式

    SpringBoot环境下junit单元测试速度优化方式

    这篇文章主要介绍了SpringBoot环境下junit单元测试速度优化方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-09-09
  • 基于SPRINGBOOT配置文件占位符过程解析

    基于SPRINGBOOT配置文件占位符过程解析

    这篇文章主要介绍了基于SPRINGBOOT配置文件占位符过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-12-12
  • 详解java配置文件的路径问题

    详解java配置文件的路径问题

    这篇文章主要介绍了详解java配置文件的路径问题的相关资料,这里对绝对路径及相对路径和classpath 类文件路径进行详细介绍,需要的朋友可以参考下
    2017-07-07
  • 浅谈Java的两种多线程实现方式

    浅谈Java的两种多线程实现方式

    本篇文章主要介绍了浅谈Java的两种多线程实现方式,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-08-08
  • Java定时清理过期文件的实例代码

    Java定时清理过期文件的实例代码

    这篇文章主要介绍了Java定时清理过期文件的实例代码,非常不错,具有一定的参考借鉴价值 ,需要的朋友可以参考下
    2018-12-12
  • java正则表达式如何获取xml文件中指定节点的值

    java正则表达式如何获取xml文件中指定节点的值

    这篇文章主要介绍了java正则表达式如何获取xml文件中指定节点的值问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-06-06
  • java短信验证码获取次数限制实例

    java短信验证码获取次数限制实例

    这篇文章主要介绍了java短信验证码获取次数限制实例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-01-01
  • mybatis 插件: 打印 sql 及其执行时间实现方法

    mybatis 插件: 打印 sql 及其执行时间实现方法

    下面小编就为大家带来一篇mybatis 插件: 打印 sql 及其执行时间实现方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-06-06
  • 详解Java数字签名提供XML安全

    详解Java数字签名提供XML安全

    在本篇文章中我们给大家整理了关于Java数字签名提供XML安全的知识点内容,有需要的朋友们可以学习下。
    2018-08-08

最新评论