为防止内存开销过大,通过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 createExcelSheet(HSSFWorkbook workbook,String sheetName,int sheetCount){
        List sheetList=new ArrayList();
        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 titleRowCells =new ArrayList();
        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 contentCells=new ArrayList();
            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 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 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  getObjectsPaging(String selectCriteria,int resultCount,int pageSize){
//      根据条件查询数据库得到的条数
        int count=0;
        if (count == 0) {
            return null;
        }
//      根据条件分页查询,得到对象集合
        return new ArrayList();
    }
}
 

 

                            
                        
                    
                    
                    

你可能感兴趣的:(为防止内存开销过大,通过Apache POI技术实现报表的分页导出,提取工具类)