使用easyExcel模板输出

一、maven依赖

	<!-- easyExcel的核心依赖,如果单独使用easyExcel只依赖此jar包即可 -->
	<dependency>
	    <groupId>com.alibaba</groupId>
	    <artifactId>easyexcel</artifactId>
	    <version>2.2.3</version>
	</dependency>
	
	<!-- 用于创建MultipartFile对象,接收easyExcel创建的文件流,并转换为具体文件 -->
	<dependency>
	    <groupId>org.springframework</groupId>
	    <artifactId>spring-web</artifactId>
	    <version>RELEASE</version>
	    <scope>compile</scope>
	</dependency>
	<dependency>
	    <groupId>org.springframework</groupId>
	    <artifactId>spring-test</artifactId>
	    <version>RELEASE</version>
	    <scope>compile</scope>
	</dependency>

二、导入模板格式要求

1、普通填充型

使用{parameter}的形式来填充,再代码中设置对应的属性,一个sheet页中的所有参数,在Java中都需要抽象成对象
在这里插入图片描述

2、循环填充型

使用{.parameter}的形式来填充,此填充类型与普通填充型最大的区别在于,他是有方向的,默认方向为从上到下
在这里插入图片描述

3、组合填充型

将普通填充和循环填充结合使用的一种方式,在使用的过程中并不完全依赖对象,有时也需要依赖容器
在这里插入图片描述

三、write()与fill()的区别

在组合填充的过程中,我们会看到两个向excel写入的方法,write()fill() ,他们有什么区别呢?
write() 多用于流的输入输出,也可以用于普通的模板填充
fill() 是模板填充的专用方法,它可以设置模板填充时的填充方向

四、输出文件流

  • 创建vo对象
@Data
public class TeacherVO {

    /**
     * 班级
     */
    private String clazz;
    /**
     * 班主任
     */
    private String instructor;
}
  • 流输出核心代码
		String path = ClassUtils.getDefaultClassLoader().getResource("").getPath();
        // 获取模板文件路径
        String tempFile = path + "static/excelTemplate.xlsx";
        // 获取文件输出路径
        String file = path + "static/excelResult.xlsx";
        // 获取需要填充的对象
        TeacherVO teacher = new TeacherVO();
        teacher.setClazz("一年级一班");
        teacher.setInstructor("张三");
        // 以输出流的形式返回给前端
        EasyExcel.write(file).withTemplate(tempFile).sheet("sheet2").doFill(teacher);

五、输出excel文件

  • 创建vo对象
@Data
public class StudentVO {

    /**
     * 学号
     */
    private String number;
    /**
     * 姓名
     */
    private String name;
    /**
     * 语文成绩
     */
    private String chineseAchievement;
    /**
     * 数学成绩
     */
    private String mathematicsAchievement;
    /**
     * 英语成绩
     */
    private String englishAchievement;
}
  • 文件输出核心代码
        String path = ClassUtils.getDefaultClassLoader().getResource("").getPath();
        // 获取excel模板
        String tempFile = path + "static/excelTemplate.xlsx";
        // 创建输出流
        try (ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream()) {
            // 将模板输出到创建的输出流中,并创建ExcelWriter对象
            ExcelWriter writer = EasyExcel.write(byteArrayOutputStream).withTemplate(tempFile).build();
            // 创建WriteSheet对象,指定输出的sheet页
            WriteSheet sheet1 = EasyExcel.writerSheet("sheet1").build();
            // 创建FillConfig对象,指定输出方向
            FillConfig fillConfig = FillConfig.builder().direction(WriteDirectionEnum.VERTICAL).build();
            // 获取需要被填充的数据
            List<StudentVO> studentList = new ArrayList<>();
            for (int i = 0; i < 10; i++) {
                StudentVO student = new StudentVO();
                student.setName("张三" + i);
                student.setNumber(String.valueOf(i));
                student.setChineseAchievement(String.valueOf(i));
                student.setMathematicsAchievement(String.valueOf(i));
                student.setEnglishAchievement(String.valueOf(i));
                studentList.add(student);
            }
            // 将数据、模板配置、sheet页信息填充到ExcelWriter对象中
            writer.fill(studentList, fillConfig, sheet1);
            // 输出文件对象
            MultipartFile multipartFile = new MockMultipartFile("file", "excelResult.xlsx", "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet", byteArrayOutputStream.toByteArray());
            
            // TODO 可以直接存储到文件服务器
        } catch (IOException e) {
            e.printStackTrace();
        }

【结束语】
        几个星期前遇到了一个需求,需要做一个导入功能,在导入数据的过程中需要将错误数据输出到一个excel表格中,我使用redis将正确数据和错误数据分别临时存储,在数据全部正确的时候一起保存数据,并将数据按照以上方式生成了一个excel文件上传到文件服务器备份,以上就是我最终的解决方案,希望可以帮助到有需要的小伙伴

  • 4
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
你可以使用EasyExcel库来创建Excel模板。首先,你需要在项目中引入EasyExcel依赖。 ```xml <dependency> <groupId>com.alibaba</groupId> <artifactId>easyexcel</artifactId> <version>2.4.5</version> </dependency> ``` 然后,你可以使用EasyExcel提供的API来创建和操作Excel文件。下面是一个简单的示例: ```java // 导入必要的类 import com.alibaba.excel.EasyExcel; import com.alibaba.excel.write.builder.ExcelWriterBuilder; import com.alibaba.excel.write.builder.ExcelWriterSheetBuilder; public class ExcelTemplateExample { public static void main(String[] args) { // 指定输出文件路径 String outputFile = "path/to/output.xlsx"; // 创建 ExcelWriterBuilder 对象 ExcelWriterBuilder writerBuilder = EasyExcel.write(outputFile); // 创建 ExcelWriterSheetBuilder 对象 ExcelWriterSheetBuilder sheetBuilder = writerBuilder.sheet("Sheet1"); // 写入数据 sheetBuilder.head("姓名", "年龄", "性别") .registerWriteHandler(new FreezeAndFilterHandler()) // 可选的写入处理器 .doWrite(dataList()); // 完成写入操作 writerBuilder.finish(); } // 模拟数据 private static List<List<Object>> dataList() { List<List<Object>> dataList = new ArrayList<>(); dataList.add(Arrays.asList("张三", 20, "男")); dataList.add(Arrays.asList("李四", 25, "女")); dataList.add(Arrays.asList("王五", 30, "男")); return dataList; } } ``` 上述示例代码创建了一个名为 "Sheet1" 的Excel文件,并写入了一些数据。你可以根据需要自定义模板的内容和样式。注意,示例中的 `FreezeAndFilterHandler` 是一个可选的写入处理器,用于冻结首行并启用筛选功能。 然后,你就可以在指定的输出路径找到生成的Excel文件。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值