java中用SXSSFWorkbook把多个字段的list数据和单个实体dto导出到excel如何导出到多个sheet页详细实例?

这篇具有很好参考价值的文章主要介绍了java中用SXSSFWorkbook把多个字段的list数据和单个实体dto导出到excel如何导出到多个sheet页详细实例?。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

要使用SXSSFWorkbook将多个字段的List数据和单个实体DTO导出到多个Sheet页,你可以按照以下步骤进行操作:

  1. 创建一个SXSSFWorkbook对象作为工作簿。
  2. 针对每个字段的List数据,创建一个新的Sheet页,并将数据写入该Sheet页。
  3. 创建一个新的Sheet页,用于单个实体DTO的数据。
  4. 将单个实体DTO的数据写入该Sheet页。
  5. 将工作簿写入Excel文件中。

以下是一个示例代码,展示了如何根据上述步骤导出多个Sheet页:

import org.apache.poi.xssf.streaming.SXSSFWorkbook;
import org.apache.poi.xssf.streaming.SXSSFSheet;
import org.apache.poi.xssf.streaming.SXSSFRow;
import org.apache.poi.xssf.streaming.SXSSFCell;

import java.io.FileOutputStream;
import java.io.IOException;
import java.util.List;

public class ExcelExporter {
    public static void exportToExcel(List<String> field1Data, List<Integer> field2Data, List<DTO> dtoList) {
        // 创建工作簿
        SXSSFWorkbook workbook = new SXSSFWorkbook();

        // 导出字段1的数据到Sheet1
        exportFieldData(workbook, field1Data, "Field 1 Data");

        // 导出字段2的数据到Sheet2
        exportFieldData(workbook, field2Data, "Field 2 Data");

        // 导出DTO数据到Sheet3
        exportDTOData(workbook, dtoList);

        try (FileOutputStream fileOut = new FileOutputStream("output.xlsx")) {
            // 将工作簿写入文件
            workbook.write(fileOut);
            System.out.println("Excel导出完成!");
        } catch (IOException e) {
            e.printStackTrace();
        } finally {
            // 关闭工作簿
            workbook.dispose();
        }
    }

    private static void exportFieldData(SXSSFWorkbook workbook, List<?> fieldData, String sheetName) {
        // 创建Sheet页
        SXSSFSheet sheet = workbook.createSheet(sheetName);

        // 写入数据
        for (int i = 0; i < fieldData.size(); i++) {
            SXSSFRow row = sheet.createRow(i);
            SXSSFCell cell = row.createCell(0);
            cell.setCellValue(fieldData.get(i).toString());
        }
    }

    private static void exportDTOData(SXSSFWorkbook workbook, List<DTO> dtoList) {
        // 创建Sheet页
        SXSSFSheet sheet = workbook.createSheet("DTO Data");

        // 写入列标题
        SXSSFRow headerRow = sheet.createRow(0);
        headerRow.createCell(0).setCellValue("Field1");
        headerRow.createCell(1).setCellValue("Field2");
        // ...

        // 写入数据
        int rowIndex = 1;
        for (DTO dto : dtoList) {
            SXSSFRow dataRow = sheet.createRow(rowIndex++);
            dataRow.createCell(0).setCellValue(dto.getField1());
            dataRow.createCell(1).setCellValue(dto.getField2());
            // ...
        }
    }

    public static class DTO {
        private String field1;
        private int field2;

        public String getField1() {
            return field1;
        }

        public void setField1(String field1) {
            this.field1 = field1;
        }

        public int getField2() {
            return field2;
        }

        public void setField2(int field2) {
            this.field2 = field2;
        }
    }
}

在上述示例中,我们创建了一个ExcelExporter类,并定义了两个导出字段的List数据(field1Data和field2Data),以及一个包含DTO对象的List(dtoList)。

exportToExcel方法根据步骤将这些数据导出到多个Sheet页。首先,我们创建一个SXSSFWorkbook对象作为工作簿。

然后,调用exportFieldData方法将field1Data和field2Data分别写入名为"Field 1 Data"和"Field 2 Data"的Sheet页中。

接下来,我们调用exportDTOData方法,将dtoList中的DTO数据写入名为"DTO Data"的Sheet页中。在该方法中,我们首先创建列标题行,然后逐行写入DTO数据。

最后,我们将工作簿写入文件,并在必要时关闭工作簿。文章来源地址https://www.toymoban.com/news/detail-668698.html

到了这里,关于java中用SXSSFWorkbook把多个字段的list数据和单个实体dto导出到excel如何导出到多个sheet页详细实例?的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【Java】Mybatis查询数据库返回JSON格式的字段映射到实体类属性

    今天遇到了一个bug,大概就是数据库(Mysql)中有一个 type 类型字段,数据类型为json,大概是这样的:[“苹果”,“香蕉”,“葡萄”]的数据格式,这个bug的问题所在呢就是查询后这个json格式的数据无法映射到我们实体类的属性上,解决方案如下: 实体类的配置: @TableField

    2024年02月15日
    浏览(48)
  • C#中使用list封装多个同类型对象以及组合拓展实体的应用

    在C#中,使用 ListT 集合是封装多个同类型对象的常用方式。 ListT 是泛型集合, T 是集合中元素的类型。下面是一个简单的例子,演示如何创建一个 ListT ,并向其中添加对象。 首先,假设我们有一个类,比如一个 Person 类,它有一些属性: 然后,我们可以这样使用 ListT : 上

    2024年02月22日
    浏览(42)
  • Java实体类属性和数据库字段都是大写字母,为什么返回给前端会变成小写字母

    最近我在开发系统的过程中发现了一个问题,我数据库中数据表的字段名使用的全是大写字母,Java实体类中属性也都是大写字母,但是返回给前端的时候所有属性名却变成了小写的。 我查阅资料后解决了问题,因此记录下来,避免以后再次踩坑。 数据库字段的字段名是大写

    2024年02月14日
    浏览(52)
  • java中,将List<Map>转为List<实体>或者List<实体>转为List<Map>

    1、ListMap转List实体  2、List实体转ListMap

    2024年01月24日
    浏览(54)
  • Java给实体每一个字段赋默认值

    目录 一、初级版 1、工具类 2、实体类与测试代码 二、升级版-多层嵌套 1、工具类 2、实体类与测试代码 三、最终版-各种集合 1、工具类 2、实体类与测试代码 1、工具类         使用反射机制实现任意实体类字段的默认值赋值功能 2、实体类与测试代码         使用

    2024年02月15日
    浏览(28)
  • 【Java】给实体每一个字段赋默认值

    目录 一、初级版 1、工具类 2、实体类与测试代码 二、升级版-多层嵌套 1、工具类 2、实体类与测试代码 三、最终版-各种集合 1、工具类 2、实体类与测试代码 1、工具类         使用反射机制实现任意实体类字段的默认值赋值功能 2、实体类与测试代码         使用

    2024年02月07日
    浏览(34)
  • Java中用Stream流对List对象集合转Map时key值重复的操作

    看完你还不懂,你直接喷·· 定义: 1.List是一个装Dto对象的集合 2.Dto里面有ID属性,name属性等等 3.Dto里面的ID会重复  现在要把List转成以ID为key值的map,明显key不能重复啊,所以应该怎么操作呢? (需要你有java8Stream流的基本概念,map的基本概念)   操作1:重复key,选择保留

    2024年01月18日
    浏览(59)
  • JAVA:使用POI SXSSFWorkbook方式导出Excel大数据文件

    Apache POI 是用Java编写的免费开源的跨平台的 Java API,Apache POI提供API给Java对Microsoft Office格式档案读和写的功能。POI组件可以提供Java操作Microsoft Office的API,导出格式为Office 2003时POI调用的HSSF包,导出格式为Office 2007时,调用XSSF包,而SXSSF包是POI3.8版本之上对XSSF的一个扩展,用

    2024年02月11日
    浏览(50)
  • Java,excel大量百万数据导出优化措施,SXSSFWorkbook流式、分批次导出示例

    在导出百万级的数据时,如果不采用适当的优化措施,确实可能会造成死机和内存崩溃等问题。 为避免这些问题,可以采用以下优化措施: 分批次读取数据:将需要导出的数据分成多个批次进行读取和写入,每次读取部分数据,写入 Excel 后即时清除内存。这样可以避免一次

    2024年02月16日
    浏览(42)
  • Java 字符串类型的JSON数组转List<Object>或 List<实体类>

    1.依赖 2.代码 3.JSON数组 [     {         \\\"_object_version\\\": 4,         \\\"updateAuthorizers\\\": [         ],         \\\"RELATED_POOL\\\": \\\"网络云-大区金华可信11\\\",         \\\"CLOUD\\\": \\\"大区网络云\\\",         \\\"modifier\\\": \\\"easyops\\\",           },     {         \\\"_object_version\\\": 4,         \\\"updateAuthorizers\\\": [    

    2024年02月14日
    浏览(58)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包