java 通过Excel模板导出复杂的Excel格式数据

接口导出Excel的时候,Excel的格式有时候很复杂,包含图片,字体居中等等格式,当然通过poi的合并单元格那些操作也能实现,但比较复杂。比如这种Excel(仅仅是测试数据):
在这里插入图片描述

这里可以直接把模板通过文件的输出流直接输出出来,然后在Excel里的单元格填写查询的数据,这样就简单多了。具体操作如下:

1. 查询出单元格要写入的数据
2. 获取Excel模板

Workbook workbook = null;
        Sheet sheet = null;
        ClassPathResource resource = new ClassPathResource("excel/analysis.xlsx");
        try {
            InputStream inputStream = resource.getInputStream();
            workbook = WorkbookFactory.create(inputStream);
            sheet = workbook.getSheetAt(0);
            workbook.setSheetName(0,"sheet页名称");
        } catch (Exception e) {
            e.printStackTrace();
        }

可以直接把未填写数据的Excel模板放在代码的resource目录下,然后读取

3.给固定位置的Excel单元格写入数据

sheet.getRow(1).getCell(1).setCellValue("单元格值");

ps: Excel的行和列都是从0开始计算

4.输出Excel

try {
            String disposition = String.format("attachment;filename=\"%s-%s.xlsx\"", sdf.format(new Date()), eventNum);
            response.setContentType("application/msexcel");
            response.setCharacterEncoding("utf-8");
            response.addHeader("Content-Disposition", disposition);
            workbook.write(response.getOutputStream());
        } catch (Exception e) {
            LOGGER.error(e.getMessage());
        } finally {
            try {
                workbook.close();
            } catch (IOException e) {
                LOGGER.error(e.getMessage());
            }
        }

以上,就可以完成复杂Excel的导出了,是不是比在POI里合并单元格,去画一个Excel简单些呢

  • 2
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
根据excel模板动态导出数据数据 package text; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; import java.util.UUID; import javax.servlet.ServletContext; import net.sf.jxls.transformer.XLSTransformer; import org.apache.struts2.ServletActionContext; import com.opensymphony.xwork2.ActionSupport; public class TextAction extends ActionSupport { /** */ private static final long serialVersionUID = 1L; private String filename; @SuppressWarnings("rawtypes") public String export() throws Exception { String templateFile = "18.xls"; // String sql = "select * from t_ry order by rybm"; // exportAndDownload(templateFile, DataBase.retrieve(sql)); List datas = new ArrayList(); @SuppressWarnings("unchecked") HashMap map = new HashMap(); map.put("name", "1111"); datas.add(map); exportAndDownload(templateFile, datas); return SUCCESS; } @SuppressWarnings({ "rawtypes", "unchecked" }) public void exportAndDownload(String templateFile, List datas) { try { filename = UUID.randomUUID() + templateFile; // FacesContext context = FacesContext.getCurrentInstance(); // ServletContext servletContext = (ServletContext) // context.getExternalContext().getContext(); ServletContext servletContext = ServletActionContext .getServletContext(); String path = servletContext.getRealPath("\\ExcelFile"); String srcFilePath = path + "\\template\\" + templateFile; String destFilePath = path + "\\download\\" + filename; Map beanParams = new HashMap(); beanParams.put("results", datas); XLSTransformer transfer = new XLSTransformer(); transfer.transformXLS(srcFilePath, beanParams, destFilePath); // Browser.execClientScript("window.location.href='../ExcelFile/downloadfile.jsp?filename=" // + destFile + "';"); } catch (Exception e) { e.printStackTrace(); } } public String getFilename() { return filename; } public void setFilename(String filename) { this.filename = filename; } }
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值