easypoi 导出工具类

China☆狼群 提交于 2019-12-19 08:14:36
package com.guanyu.evaluation.questionnaire.utils;

import cn.afterturn.easypoi.excel.entity.ExportParams;
import cn.afterturn.easypoi.excel.entity.enmus.ExcelType;
import cn.afterturn.easypoi.excel.entity.params.ExcelExportEntity;
import cn.afterturn.easypoi.excel.export.ExcelExportService;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.ss.usermodel.Workbook;
import org.apache.poi.xssf.streaming.SXSSFWorkbook;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;

import java.util.Collection;
import java.util.List;
import java.util.Map;

/**
 * Excel多sheet的导出
 * @author 
 * @since  2019-10-13
 */
public class ExcelMultiSheetExportUtil {


    /**
     * 基于注解的方式
     * 一个excel 创建多个sheet
     *
     * @param list
     *            多个Map key title 对应表格Title key entity 对应表格对应实体 key data
     *            Collection 数据
     * @return
     */
    public static Workbook exportExcel(List<Map<String, Object>> list, ExcelType type) {
        Workbook workbook = getWorkbook(type,0);
        for (Map<String, Object> map : list) {
            ExcelExportService service = new ExcelExportService();
            service.createSheetForMap(workbook, (ExportParams)map.get("title"), (List<ExcelExportEntity>)map.get("entity"), (Collection<?>)map.get("data"));
        }
        return workbook;
    }

    /**
     * 基于编码的方式
     * 实现一个excel 创建多个sheet
     * entity 对应表格对应实体 key data Collection 数据
     * @param entity
     * @param entityList
     * @param dataSet
     * @return
     */
    public static Workbook exportExcel(ExportParams entity, List<ExcelExportEntity> entityList, Collection<?> dataSet) {
        Workbook workbook = getWorkbook(entityList.size());
        ExcelExportService service = new ExcelExportService();
        service.createSheetForMap(workbook,entity,entityList,dataSet);
        return workbook;
    }

    /**
     * 当数据量超出65536条后,在使用HSSFWorkbook或XSSFWorkbook,
     * 程序会报OutOfMemoryError:Javaheap space;内存溢出错误。
     * 这时应该用SXSSFworkbook。
     * @param size
     * @return
     */
    private static Workbook getWorkbook(ExcelType type, int size) {
        if (ExcelType.HSSF.equals(type)) {
            return new HSSFWorkbook();
        } else if (size < 100000) {
            return new XSSFWorkbook();
        } else {
            return new SXSSFWorkbook();
        }
    }

    /**
     * sheetlist的大小
     * @param size
     * @return
     */
    private static Workbook getWorkbook(int size) {
        if (size < 56636) {
            return new HSSFWorkbook();
        } else if (size < 100000) {
            return new XSSFWorkbook();
        } else {
            return new SXSSFWorkbook();
        }
    }
}

 

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!