使用EasyExcel导出多个sheet表格

一、easyexcel导出多个sheet表格模板

在使用EasyExcel导出多个Sheet表格时,我们首先需要创建不同的Sheet表格模板。为此,我们可以通过 EasyExcel 的 WriteModel 模式,创建多个不同的Model并使用不同的Sheet存储在同一个Excel文件中。需要注意的是,多个Sheet在创建时,需要指定不同的Sheet名称。

public void writeSeveralSheetsWithTemplate(String filePath){
    List modelList = new ArrayList();
    WriteModel model1 = new WriteModel();
    model1.setName("Sheet1");
    List<List> data1 = new ArrayList();
    data1.add(Arrays.asList("姓名", "年龄", "性别"));
    model1.setData(data1);
    modelList.add(model1);

    WriteModel model2 = new WriteModel();
    model2.setName("Sheet2");
    List<List> data2 = new ArrayList();
    data2.add(Arrays.asList("学科", "成绩"));
    model2.setData(data2);
    modelList.add(model2);

    EasyExcel.write(filePath).withTemplate(templateFileName).sheet().doWrite(modelList);
}

二、easyexcel导出数据

在创建好多个Sheet表格模板后,我们需要将我们需要导出的数据填充到每一个模板中。可以通过 EasyExcel 的 WriteModel 模式,将数据填充到对应的Sheet表格中。

public void writeSeveralSheetsWithData(String filePath){
    List modelList = new ArrayList();
    WriteModel model1 = new WriteModel();
    model1.setName("Sheet1");
    List<List> data1 = new ArrayList();
    data1.add(Arrays.asList("小明", "18", "男"));
    data1.add(Arrays.asList("小红", "17", "女"));
    model1.setData(data1);
    modelList.add(model1);

    WriteModel model2 = new WriteModel();
    model2.setName("Sheet2");
    List<List> data2 = new ArrayList();
    data2.add(Arrays.asList("语文", "80"));
    data2.add(Arrays.asList("数学", "90"));
    model2.setData(data2);
    modelList.add(model2);

    EasyExcel.write(filePath).withTemplate(templateFileName).sheet().doWrite(modelList);
}

三、easyexcel导出无数据

如果需要在导出Excel文件时,给一些Sheet表格添加无数据提示信息,则可以通过添加一个空的List,来实现该功能。

public void writeSeveralSheetsWithEmptyData(String filePath){
    List modelList = new ArrayList();
    WriteModel model1 = new WriteModel();
    model1.setName("Sheet1");
    List<List> data1 = new ArrayList();
    data1.add(Arrays.asList("小明", "18", "男"));
    model1.setData(data1);
    modelList.add(model1);

    WriteModel model2 = new WriteModel();
    model2.setName("Sheet2");
    List<List> data2 = new ArrayList();
    // 添加空的List
    model2.setData(data2);
    modelList.add(model2);

    EasyExcel.write(filePath).withTemplate(templateFileName).sheet().doWrite(modelList);
}

四、easyexcel模板导出选取

通过EasyExcel,我们可以实现对指定Sheet表格数据的导出。想要实现该功能,我们需要创建指定的Sheet表格模板,并在使用时,只选取需要的Sheet表格进行数据填充并导出。

public void writeSelectedSheetsWithData(String filePath){
    List modelList = new ArrayList();
    WriteModel model1 = new WriteModel();
    model1.setName("Sheet1");
    List<List> data1 = new ArrayList();
    data1.add(Arrays.asList("小明", "18", "男"));
    data1.add(Arrays.asList("小红", "17", "女"));
    model1.setData(data1);
    modelList.add(model1);

    WriteModel model2 = new WriteModel();
    model2.setName("Sheet2");
    List<List> data2 = new ArrayList();
    data2.add(Arrays.asList("语文", "80"));
    data2.add(Arrays.asList("数学", "90"));
    model2.setData(data2);
    modelList.add(model2);

    EasyExcel.write(filePath).withTemplate(templateFileName)
             .sheet("Sheet1")
             .doWrite(modelList.stream().filter(model -> model.getName().equals("Sheet1"))
                                      .collect(Collectors.toList()));
}

原创文章,作者:小蓝,如若转载,请注明出处:https://www.506064.com/n/151534.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
小蓝小蓝
上一篇 2024-11-11 13:42
下一篇 2024-11-11 13:42

相关推荐

  • 为什么Python不能编译?——从多个方面浅析原因和解决方法

    Python作为很多开发人员、数据科学家和计算机学习者的首选编程语言之一,受到了广泛关注和应用。但与之伴随的问题之一是Python不能编译,这给基于编译的开发和部署方式带来不少麻烦…

    编程 2025-04-29
  • Java判断字符串是否存在多个

    本文将从以下几个方面详细阐述如何使用Java判断一个字符串中是否存在多个指定字符: 一、字符串遍历 字符串是Java编程中非常重要的一种数据类型。要判断字符串中是否存在多个指定字符…

    编程 2025-04-29
  • 使用Treeview显示表格

    在web开发中,显示表格数据是一项很常见的需求。当我们需要在页面上显示大量数据时,除了使用传统的表格样式外,还可以使用Treeview这种可折叠的表格样式,以便更好地展示数据。本文…

    编程 2025-04-29
  • Python合并多个相同表头文件

    对于需要合并多个相同表头文件的情况,我们可以使用Python来实现快速的合并。 一、读取CSV文件 使用Python中的csv库读取CSV文件。 import csv with o…

    编程 2025-04-29
  • Python根据表格数据生成折线图

    本文将介绍如何使用Python根据表格数据生成折线图。折线图是一种常见的数据可视化图表形式,可以用来展示数据的趋势和变化。Python是一种流行的编程语言,其强大的数据分析和可视化…

    编程 2025-04-29
  • Python 图片转表格

    本文将详细介绍如何使用Python将图片转为表格。大家平时在处理一些资料的时候难免会遇到图片转表格的需求。比如从PDF文档中提取表格等场景。当然,这个功能也可以通过手动复制、粘贴,…

    编程 2025-04-29
  • 从多个方面用法介绍yes,but let me review and configure level of access

    yes,but let me review and configure level of access是指在授权过程中,需要进行确认和配置级别控制的全能编程开发工程师。 一、授权确…

    编程 2025-04-29
  • 从多个方面zmjui

    zmjui是一个轻量级的前端UI框架,它实现了丰富的UI组件和实用的JS插件,让前端开发更加快速和高效。本文将从多个方面对zmjui做详细阐述,帮助读者深入了解zmjui,以便更好…

    编程 2025-04-28
  • python爬取网页并生成表格

    本文将从以下几个方面详细介绍如何使用Python爬取网页数据并生成表格: 一、获取网页数据 获取网页数据的一般思路是通过HTTP请求获取网页内容,最常用的方式是使用Python库r…

    编程 2025-04-28
  • 学Python用什么编辑器?——从多个方面评估各种Python编辑器

    选择一个适合自己的 Python 编辑器并不容易。除了我们开发的应用程序类型、我们面临的软件架构以及我们的编码技能之外,选择编辑器可能也是我们编写代码时最重要的决定之一。随着许多不…

    编程 2025-04-28

发表回复

登录后才能评论