阿里EasyExcel对Excel复杂模版填充实现并设置单元格格式

本文介绍了如何使用阿里EasyExcel库在Java中实现对复杂Excel模板的填充,并通过`History2014ExportCellWriteHandler`设置单元格样式。详细步骤包括添加EasyExcel依赖、创建实体Bean、设计模板、编写Controller代码,以及展示最终的导出结果。
摘要由CSDN通过智能技术生成

easyExcel模版示例地址:

接下来代码展示

1.添加easyExcel依赖

	<dependency>
		<groupId>com.alibaba</groupId>
		<artifactId>easyexcel</artifactId>
		<version>2.2.3</version>
	</dependency>

2.创建一个类似于实体的Bean

package com.zykj.common.util.bean;

import com.alibaba.excel.annotation.write.style.ColumnWidth;
import com.alibaba.excel.annotation.write.style.ContentRowHeight;
import com.alibaba.excel.annotation.write.style.HeadRowHeight;
import lombok.Data;

import java.math.BigDecimal;

@Data
public class ExportReconciliationClearFormBean {
   

    //标题
    public String title;
    //序号
    public int number;
    //日期
    public String date;
    //业务系统人数
    public int number_of_business_system;
    //业务系统金额
    public BigDecimal business_system_amount;
    //财务到账人数
    public int number_of_people_in_the_account;
    //财务到账金额
    public BigDecimal financial_receipt_amount;
    //人数差异
    public int poor_number_of_people;
    //金额差异
    public BigDecimal difference_in_amount;
    //业务系统人数合计
    public int yw_people_count;
    //业务系统金额合计
    public BigDecimal yw_amount_count;
    //财务到账人数合计
    public int cw_people_count;
    //财务到账金额合计
    public BigDecimal cw_amount_count;
    //人数差异合计
    public int poor_number_of_people_count;
    //金额差异合计
    public BigDecimal difference_in_amount_count;
    //备注
    public String remarks;
		//这里省略了get和set方法 记得添加
   
    }
}

3.根据你的需求创建摸版

{xxx}是Map填充 xxx对应key value放所对应的值
{.xxx}是list填充 xxx对应着list的名称 如果是list<上面创建的bean> 那xxx对应bean的属性

摸版

4.后台Controller代码

/**
     * 导出对账确认表
     * qyh
     */
    public void exportReconciliationClearForm() throws IOException, ParseException {
   
        Map<String,Object> map = new HashMap<>();
        List<ExportReconciliationClearFormBean> bean = new ArrayList<ExportReconciliationClearFormBean>();
        String date = getPara("date");
        SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
        //开始时间
        String tartingTime = date.substring(0,date.indexOf(" -"));
        //结束时间
        String endTime = date.substring(date.lastIndexOf("- ")+1,date.length());

        //系统类型 1职称 2计算机英语 3协会
        String orderType = getPara("orderType");
        map.put("tartingTime",sdf.parse(tartingTime.replace("/","-")));
        map.put("endTime",sdf.parse(endTime.replace("/","-")));
        map.put("orderType",orderType);
        int randInt = (int) ((Math.random() * 9 + 1) * 1000);
        String fileName = RdmUtils.replaceSign(endTime)+ randInt + ".zip";
        getResponse().setContentType("APPLICATION/OCTET-STREAM");
        //b.Content-Disposition 设置要被下载的文件名
        getResponse().setHeader("Content-Disposition", "attachment;filename=" + fileName);
        //获取输出流
        ServletOutputStream out = getResponse().getOutputStream();
        //计算机英语系统  报名 用书 证书
        String computerEnglish = getPara("orderTypeTwo");
        String[] computerEnglishType = computerEnglish.split(",");
        List<File> listFile = new ArrayList
  • 8
    点赞
  • 49
    收藏
    觉得还不错? 一键收藏
  • 14
    评论
EasyExcel中,使用ExcelWriter基于Excel模板填充时,可以使用注解`@ExcelProperty`来指定数据在Excel模板中的位置,并使用`@ContentRowHeight`、`@HeadRowHeight`、`@HeadStyle`、`@ContentStyle`等注解来设置单元格的样式和格式。 而对于合并单元格,可以使用`@ContentLoopMerge`注解来实现。具体步骤如下: 1.在Excel模板中设置需要合并的单元格。例如,我们需要将第2列的数据按照第1列的值进行合并,则可以在第1列的单元格设置`@ContentLoopMerge(name = "name")`注解来指定需要合并的单元格。如下所示: ``` | 姓名 | 年龄 | 性别 | |------|------|------| | A | 20 | 男 | | A | 25 | 女 | | B | 30 | 男 | | B | 35 | 女 | ``` 2.在实体类中使用`@ExcelProperty`注解来指定数据在Excel模板中的位置。同时,使用`@ContentLoopMerge(name = "name")`注解来指定需要合并的单元格。如下所示: ```java public class User { @ExcelProperty(value = "姓名", index = 0) @ContentLoopMerge(name = "name") private String name; @ExcelProperty(value = "年龄", index = 1) private Integer age; @ExcelProperty(value = "性别", index = 2) private String gender; // getter和setter方法省略 } ``` 3.在代码中使用`ExcelWriter`对象来填充数据,使用`FillConfig`对象来设置`@ContentLoopMerge`注解的参数。如下所示: ```java // 加载Excel模板 InputStream templateInputStream = new FileInputStream("template.xlsx"); Template template = TemplateUtil.loadTemplate(templateInputStream); // 创建ExcelWriter对象 ExcelWriter writer = EasyExcel.write(outputStream).withTemplate(template).build(); // 设置FillConfig对象 FillConfig fillConfig = FillConfig.builder().forceNewRow(Boolean.TRUE).build(); // 填充数据 List<User> userList = getUserList(); writer.fill(userList, fillConfig, new Sheet(0)); // 关闭ExcelWriter对象 writer.finish(); ``` 在上面的示例中,我们首先加载Excel模板,然后创建`ExcelWriter`对象,设置`FillConfig`对象并填充数据。其中,`forceNewRow`参数表示是否强制创建新的行,`Sheet`对象表示填充数据的Sheet页。
评论 14
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值