填充Excel

java 复制代码
import cn.hutool.core.collection.CollectionUtil;
import cn.hutool.core.util.StrUtil;
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;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import org.springframework.validation.annotation.Validated;

import javax.annotation.Resource;
import javax.servlet.http.HttpServletResponse;
import java.io.InputStream;
import java.net.URLEncoder;
import java.nio.charset.StandardCharsets;
import java.time.LocalDate;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
import java.util.function.Function;
import java.util.stream.Collectors;

    public void infoExport(TestSaveReqVO exportReqVO, HttpServletResponse response) {
        TestSaveReqVO result = BeanUtils.toBean(exportReqVO, TestSaveReqVO.class);
        getInfo(result);
        InputStream inputStream = null;
        try {
            inputStream = XXX.class.getClassLoader().getResourceAsStream("template/xxx_template.xlsx");

            response.setHeader("Access-Control-Expose-Headers", "Content-Disposition");
            response.setContentType("application/vnd.ms-excel;charset=UTF-8");
            response.setHeader("Content-Disposition", "attachment;filename=" + URLEncoder.encode("xxxxx表.xlsx", StandardCharsets.UTF_8));

            ExcelWriter writer = EasyExcel.write(response.getOutputStream()).withTemplate(inputStream).build();
            WriteSheet sheet = EasyExcel.writerSheet().build();
            // 开启填充换行
            FillConfig fillConfig = FillConfig.builder().forceNewRow(true).build();

            writer.fill(result, fillConfig, sheet);
            writer.finish();

        } catch (Exception e) {
            log.error("fail to export excel:", e);
        } finally {
            if (inputStream != null) {
                try {
                    inputStream.close();
                } catch (Exception e) {
                    log.error("fail close stream:", e);
                }
            }
        }
    }
	
	public void download(Long id, HttpServletResponse response) {
        TestRespVO resultVO = getInfo(id);
        Map<String, Object> downloadInfo = getDownLoadInfo(resultVO);
        InputStream inputStream = null;
        try {
            inputStream = xxxxx.class.getClassLoader().getResourceAsStream("template/xxxxm.xlsx");

            response.setHeader("Access-Control-Expose-Headers", "Content-Disposition");
            response.setContentType("application/vnd.ms-excel;charset=UTF-8");
            response.setHeader("Content-Disposition", "attachment;filename=" + URLEncoder.encode("xxxx单.xlsx", StandardCharsets.UTF_8));

            ExcelWriter writer = EasyExcel.write(response.getOutputStream()).withTemplate(inputStream).build();
            WriteSheet sheet = EasyExcel.writerSheet().build();
            // 开启填充换行
            FillConfig fillConfig = FillConfig.builder().forceNewRow(true).build();

            writer.fill(downloadInfo, fillConfig, sheet);
            writer.finish();
        } catch (Exception e) {
            log.error("fail to export excel:", e);
        } finally {
            if (inputStream != null) {
                try {
                    inputStream.close();
                } catch (Exception e) {
                    log.error("fail close stream:", e);
                }
            }
        }
    }
相关推荐
tedcloud1231 天前
DeepSeek-TUI部署教程:打造CLI AI助手环境
服务器·人工智能·word·excel·dreamweaver
Metaphor6922 天前
使用 Python 在 Excel 中查找并高亮显示
python·信息可视化·excel
2501_930707782 天前
使用C#代码隐藏或显示 Excel 中的批注
excel
霸道流氓气质2 天前
Excel 数据导出实战指南
excel·状态模式
雨季mo浅忆2 天前
记录利用Cursor快速实现Excel共享编辑
前端·excel
神奇的代码在哪里2 天前
【单机离线版】excel转json软件,纯HTML+JS零依赖实现Excel转JSON工具,一个index.html搞定所有转换!
html·json·excel·excel转json·xlsx转json·xls转json
DS随心转APP4 天前
AI 一键导出 Word 与 Excel 实战应用指南
人工智能·ai·word·excel·deepseek·ai导出鸭
spencer_tseng4 天前
excel 2003 [Cell division function]
excel·office
开开心心就好4 天前
小白友好的程序联网封锁实用工具
windows·eureka·计算机外设·rabbitmq·word·excel·csdn开发云
SunnyDays10114 天前
Python操作Excel批注:从基础添加到高级自定义的完整指南
开发语言·python·excel