美文网首页
为防止内存开销过大,通过Apache POI技术实现报表的分页导

为防止内存开销过大,通过Apache POI技术实现报表的分页导

作者: iMUST_Clown | 来源:发表于2019-08-03 01:42 被阅读0次

    本文内容

    • 基于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>();
        }
    }
     
    
    

    相关文章

      网友评论

          本文标题:为防止内存开销过大,通过Apache POI技术实现报表的分页导

          本文链接:https://www.haomeiwen.com/subject/fysddctx.html