2022-08-11 EasyPoi如何导出数据量较大的Excel

相信大家一定在工作工程中经历过数据量大,普通的导出已经满足不了实际需求,那么这里我给大家分享一个稍微有点用的,使用easyPoi导出数据比较大的方法

本方法是同步接口,如果导出数据量大于1048576行的,可以出门左转了,因为下列方法并不能解决这个问题,只能后台走异步导出
在这里插入图片描述

~~ 就不多BB了,直接开始~~
我项目用的gradle+jpa,所以以下就用该环境举例。

在这里插入图片描述

1.导入依赖

poi版本
	compile("cn.afterturn:easypoi-base:4.2.0")
    compile("cn.afterturn:easypoi-web:4.2.0")
    compile("cn.afterturn:easypoi-annotation:4.2.0")

2.实体类加@Excel注解

 	@ApiModelProperty("审批通过时间")
    @Excel(name = "审批通过时间", width = 16)
    private Date ApprovalsDate;

    @ApiModelProperty("是否删除")
    @Excel(name = "是否删除", width = 16 ,replace = {"是_true", "否_false"})
    private boolean isDelete;
    
    @ApiModelProperty("产品孔数")
    @Excel(name = "产品孔数", width = 16, type = 10)
    private BigDecimal wallThickness;

(注:这里我举了三个例子,小白看过来,replace可以将 _ 后面的值替换成前面的值,然后type=10是将该值导出为数字类型)

3.业务层实现IExcelExportServer 接口

这里需要重写selectListForExcelExport方法,如果是mybatis同理。

@Service
public class AdsPchAmtSumMxExclDetMqService implements IExcelExportServer {

    @Autowired
    private AdsPchAmtSumMxExclDetMqDao dao;

    @Override
    public List<Object> selectListForExcelExport(Object queryParams, int page) {
        Search search = (Search) queryParams;
        PageInfo pageInfo = new PageInfo();
        pageInfo.setPage(page);
        pageInfo.setRows(10000);
        search.setPageInfo(pageInfo);
        LogUtil.bizLog("当前是第"+page+"页,已取"+pageInfo.getRows()*(page-1)+"条数据");
        List materialResponses = dao.findByPage(search).getRows();
        return materialResponses;
    }
}

4.实际导出方法

ExcelType选择XSSF,对应excel 07的 .xlsx版本。
exportBigExcel方法这里推荐使用

public static Workbook exportBigExcel(ExportParams entity, Class<?> pojoClass,
                                          IExcelExportServer server, Object queryParams) {
        ExcelBatchExportService batchServer = new ExcelBatchExportService();
        batchServer.init(entity, pojoClass);
        return batchServer.exportBigExcel(server, queryParams);
    }

上面的这一个方法,需要传入
1.导出参数
2.导出实体的class对象
3.刚才继承IExcelExportServer 接口的业务层
4.筛选条件(这里的筛选条件就是上面重写方法里面需要用的参数)

	@Override
    public void exportDataDetail(Search search,HttpServletRequest request,HttpServletResponse response){
   			String exportName ="大数据Excel导出";
            ExportParams exportParams = new ExportParams(exportName,exportName, ExcelType.XSSF);
            Workbook workbook = ExcelExportUtil.exportBigExcel(exportParams, AdsPchAmtSumMxExclDetMq.class, adsPchAmtSumMxExclDetMqService,search);
            ExcelUtils.outputFile(request, response, workbook, exportName + ".xlsx");
    }

PS:到这里我就觉得差不多了,大家如果有什么疑问可以在下面交流哦,我哪里写的不对的地方也可以提出来共同进步!

在这里插入图片描述

夏波!夏波!

  • 5
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
### 回答1: easypoi是一款Java的POI扩展库,可以方便地将Java对象转换为Excel、Word、PDF等格式的文档。使用easypoi导出Excel大量数据非常简单,只需要将数据封装成Java对象,然后使用easypoi提供的API即可。同时,easypoi还支持Excel的样式设置、图片插入等功能,可以满足各种导出需求。 ### 回答2: Easypoi是一款基于POI的Java开发框架,它可以简化与Microsoft Excel文档交互的过程,提供了易于使用的API,使开发人员能够快速构建和导出Excel文档。 在导出大量数据的情况下,Easypoi的性能表现非常出色,它采用了多线程和文件流的方式进行数据的处理和输出,大大提高了导出效率,避免了出现内存溢出等问题。 Easypoi可以支持多种数据源的导出,包括List、Map、JavaBean等,开发人员可以根据具体业务需求选择合适的数据源进行导出。同时,Easypoi提供了丰富的样式设置和模板功能,通过对样式的设置和模板文件的使用,可以实现复杂数据的导出。 在使用Easypoi进行大量数据导出的过程中,需要注意以下几点: 1. 数据的准备:在导出之前需要确保数据完整、正确。若数据源较大,可以考虑进行分页处理。 2. 导出样式的设置:Easypoi提供了多种样式设置的方法,如字体、颜色、边框等,可以通过设置样式让导出Excel文档更加美观。 3. 模板的设计与使用:如果需要导出的数据比较复杂,可以考虑使用模板,将数据填充到模板中,模板文件中的样式和格式将会在导出文档中自动保留。 4. 文件流和多线程的使用:为了提高导出效率并避免内存溢出等问题,可以采用文件流和多线程的方式进行数据的处理和输出。 总之,Easypoi作为一款高效、易用的Excel导出框架,为我们提供了便利的开发和导出Excel文档的方法。在使用Easypoi导出大量数据时,需要注意一些细节,以确保导出的文档准确完整、美观清晰。 ### 回答3: EasyPoi是一款基于Apache POI封装的Java Excel操作工具,它提供了简单易用的API,使得导出Excel变得非常简单方便。在处理大量数据时,EasyPoi也是非常适用的。 首先,在导出大量数据时,需要使用PoiBaseView来创建Excel对象。它可以优化内存使用,避免内存溢出的问题。我们可以通过以下代码来创建PoiBaseView: ``` public class MyExcelView extends PoiBaseView { @Override protected void buildExcelDocument(Map<String, Object> model, Workbook workbook, HttpServletRequest request, HttpServletResponse response) throws Exception { // 将数据写入Excel,以下省略 } } ``` 其次,我们需要设置分页导出,即每次导出指定数量的数据,以免一次性导出过多数据导致内存溢出。EasyPoi提供了一个非常方便的分页导出工具类,我们可以通过以下代码来设置分页: ``` ExportParams params = new ExportParams("标题", "表名"); params.setType(ExcelType.XSSF); // 设置Excel格式,XSSF为xlsx,HSSF为xls params.setSheetName("Sheet1"); // 设置Sheet名 params.setCreateHeadRows(true); // 设置是否创建头部信息 params.setFreezePane(1, 1); // 冻结第一行 params.setPageNum(10000); // 每次导出10000条数据 ``` 最后,我们需要配置导出数据的格式。EasyPoi提供了非常丰富的注解来配置导出数据格式,比如@Excel、@ExcelIgnore等。我们可以通过以下代码来配置导出数据格式: ``` public class User { @Excel(name = "ID", width = 25) private String id; @Excel(name = "姓名", width = 25) private String name; @Excel(name = "年龄", width = 25) private Integer age; //省略get/set方法 } ``` 以上是针对EasyPoi导出大量数据的简单介绍。EasyPoi提供了方便易用的接口,处理大量数据时也能得到非常好的性能表现。在实际应用中,我们可以根据具体需求进行更加详细的配置,以满足不同场景下的需求。
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值