为防止内存开销过大,通过Apache POI技术实现报表的分页导出,提取工具类

本文内容

  • 基于Apache POI 工具实现Excel报表分页导出,防止可能出现的大量数据导致的崩溃等
  • 抽取为通用工具类

前置知识

  • 数组
  • 集合
  • 循环
  • 包括但不限于以上

代码如下:

工具类

可以创建工作薄的sheet页信息和表格信息。 目前暂未很好实现自动列宽功能,暂时外部传值进来。
package workhard.poiUtil;

import java.util.ArrayList;
import java.util.List;

import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFCellStyle;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.ss.usermodel.HorizontalAlignment;

public class POIUtil {
    /**
     * 根据调节创建sheet页和sheet页名称
     * @param workbook
     * @param sheetName
     * @param sheetCount
     * @return
     */
    public static List<HSSFSheet> createExcelSheet(HSSFWorkbook workbook,String sheetName,int sheetCount){
        List<HSSFSheet> sheetList=new ArrayList<HSSFSheet>();
        for (int i = 0; i < sheetCount; i++) {
            sheetList.add(i,workbook.createSheet(sheetName+"-"+(i+1)));
        }
        return sheetList;
        
    }
    /**
     * 创建sheet内容
     * @param sheet
     * @param cellWidth
     * @param columnCount
     * @param rowCount
     * @param titleStyle
     * @param titleNames
     * @param contentStyle
     * @param contentStrs
     * @return
     */
    public static HSSFSheet createHSSFSheetContent(HSSFSheet sheet,int[] cellWidth,int columnCount,int rowCount,HSSFCellStyle titleStyle,String[] titleNames,HSSFCellStyle contentStyle,String contentStrs[][]){
//      列宽
        for (int i = 0; i < columnCount; i++) {
            sheet.setColumnWidth(i, 256*cellWidth[i]);
        }
//      编写表头区域
        HSSFRow titleRow=sheet.createRow(0);
        List<HSSFCell> titleRowCells =new ArrayList<HSSFCell>();
        for (int tcol = 0; tcol < columnCount ; tcol++) {
            titleRowCells.add(titleRow.createCell(tcol));
            titleRowCells.get(tcol).setCellStyle(titleStyle);
            titleRowCells.get(tcol).setCellValue(titleNames[tcol]);
        }
//      编写内容区域
        for (int row = 0; row < rowCount; row++) {
            HSSFRow contentRow=sheet.createRow(row+1);
            List<HSSFCell> contentCells=new ArrayList<HSSFCell>();
            for (int col = 0; col < columnCount; col++) {
                contentCells.add(contentRow.createCell(col));
                contentCells.get(col).setCellStyle(contentStyle);
                contentCells.get(col).setCellValue(contentStrs[row][col]);
            }
        }
        return sheet;
    }
    /**
     * 假定通用标题样式
     * @param workbook
     * @return
     */
    public static HSSFCellStyle createTitleStyle(HSSFWorkbook workbook) {
        HSSFCellStyle titleStyle=workbook.createCellStyle();
        titleStyle.setAlignment(HorizontalAlignment.CENTER);
        return titleStyle;
    }
    /**
     * 假定内容样式
     * @param workbook
     * @return
     */
    public static HSSFCellStyle createContenrStyle(HSSFWorkbook workbook) {
        HSSFCellStyle contentStyle=workbook.createCellStyle();
        contentStyle.setAlignment(HorizontalAlignment.CENTER);
        return contentStyle;
    }
}

测试类

和业务进行关联,返回一个HSSFWorkbook实例,写入到流中,返回到页面,即可实现通过浏览器导出Excel报表的操作。
package workhard.poiUtil;

import java.util.ArrayList;
import java.util.List;

import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;

public class POIUtilTest{
    private static int DEFAULT_SELECT_COUNT=15000;
    
    public HSSFWorkbook exportReportForm(String selectCriteria) {
//      根据条件查询数据库得到的条数
        int count=0;
        if (count == 0) {
            return null;
        }
//      分页数
        int page=count/DEFAULT_SELECT_COUNT+1;
        int sheetCount=page+1;
        HSSFWorkbook workbook=new HSSFWorkbook();
        List<HSSFSheet> sheetList = POIUtil.createExcelSheet(workbook, "这里是sheet页名", sheetCount);
        String titleNames[]= {"列0","列1","列2","列3","列4","列5"};
        int titleCount=titleNames.length;
//      中文记得乘2
        int cellWidth[]= {10,16,20,14,18};
        for (int i = 0; i < page; i++) {
            //后面根据分页查询出来的
            List<Object> objectList=getObjectsPaging(selectCriteria, DEFAULT_SELECT_COUNT*page, DEFAULT_SELECT_COUNT);
            int rowCount=objectList.size();
            String contentStrs[][]=new String[titleCount][DEFAULT_SELECT_COUNT];
            for (int row = 0; row < objectList.size() ; row++) {
                contentStrs[row][0]=objectList.get(row).toString();//这里面用String类型的元素最好,如果不是,建议新建get方法转换。
                contentStrs[row][1]=objectList.get(row).toString();
                contentStrs[row][2]=objectList.get(row).toString();
                contentStrs[row][3]=objectList.get(row).toString();
            }
            POIUtil.createHSSFSheetContent(sheetList.get(page), cellWidth, titleCount, rowCount, POIUtil.createTitleStyle(workbook), titleNames, POIUtil.createContenrStyle(workbook), contentStrs);
        }
        return null;
        
    }
    
    public List<Object>  getObjectsPaging(String selectCriteria,int resultCount,int pageSize){
//      根据条件查询数据库得到的条数
        int count=0;
        if (count == 0) {
            return null;
        }
//      根据条件分页查询,得到对象集合
        return new ArrayList<Object>();
    }
}
 

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 转自链接 目录 1.认识NPOI 2.使用NPOI生成xls文件 2.1创建基本内容 2.1.1创建Workboo...
    腿毛裤阅读 13,669评论 1 3
  • 使用首先需要了解他的工作原理 1.POI结构与常用类 (1)创建Workbook和Sheet (2)创建单元格 (...
    长城ol阅读 12,704评论 2 25
  • POI操作Excel Excel简介一个excel文件就是一个工作簿workbook,一个工作簿中可以创建多张工作...
    灰气球阅读 10,191评论 2 48
  • 实习第二周 No.2 项目功能里要求能够将展示的报表导出excel,因为报表的数据都是动态从list传进来的,所...
    苏筱筑阅读 7,055评论 2 7
  • 我们在做这个项目的时候,需要导出一个excel文件,所以我就想到了使用poi导出数据 下面把代码贴出来,供大家参考...
    Harry小哥哥阅读 6,367评论 0 6