1.xls一个sheet只能装65536行,多余则报错

poi包导出或写入excel超出65536报错: 
java.lang.IllegalArgumentException: Invalid row number (65536) outside allow 

解决:每6w分一个sheet,关键代码红色部分

 

import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFCellStyle;
import org.apache.poi.hssf.usermodel.HSSFDataFormat;
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.CellStyle;
import org.apache.poi.ss.usermodel.Font;
import org.apache.poi.ss.util.CellRangeAddress;

import com.google.gson.JsonArray;
import com.google.gson.JsonObject;


public class ExcelUtil {
     public static HSSFWorkbook getHSSFWorkbook(String sheetName, JsonArray title,
            String[][] values, HSSFWorkbook wb) {

        // 第一步,创建一个HSSFWorkbook,对应一个Excel文件
        if (wb == null) {
            wb = new HSSFWorkbook();
        }

        // -个sheet限制存65536条,此处仅存60000
        System.out.println(values.length);
        final int sheetNum = (int) Math.ceil((float) values.length / 60000);
        for (int n = 1; n <= sheetNum; n++) {

            // 第二步,在workbook中添加一个sheet,对应Excel文件中的sheet
            final HSSFSheet sheet = wb.createSheet(sheetName + "_" + n);
            System.out.println("sheetName" + sheetName + "_" + n);
            sheet.setDefaultColumnWidth(12);

            // 第三步,在sheet中添加表头第0行,注意老版本poi对Excel的行数列数有限制
            HSSFRow row;

            // 第四步,创建单元格,并设置值表头样式
            final HSSFCellStyle headerStyle = wb.createCellStyle();
            headerStyle.setAlignment(CellStyle.ALIGN_CENTER); // 水平居中
            headerStyle.setVerticalAlignment(CellStyle.VERTICAL_CENTER);// 垂直居中
            final Font fontStyle = wb.createFont(); // 字体样式
            fontStyle.setBoldweight(Font.BOLDWEIGHT_BOLD); // 加粗
            fontStyle.setFontName("黑体"); // 字体
            fontStyle.setFontHeightInPoints((short) 11); // 大小
            // 将字体样式添加到单元格样式中
            headerStyle.setFont(fontStyle);
            // 边框
            headerStyle.setBorderBottom(CellStyle.BORDER_THIN);
            headerStyle.setBorderLeft(CellStyle.BORDER_THIN);
            headerStyle.setBorderRight(CellStyle.BORDER_THIN);
            headerStyle.setBorderTop(CellStyle.BORDER_THIN);

            // 普通单元格样式,边框,水平居中
            final HSSFCellStyle cellStyle = wb.createCellStyle();
            cellStyle.setAlignment(CellStyle.ALIGN_CENTER); // 水平居中
            cellStyle.setBorderBottom(CellStyle.BORDER_THIN);
            cellStyle.setBorderLeft(CellStyle.BORDER_THIN);
            cellStyle.setBorderRight(CellStyle.BORDER_THIN);
            // cellStyle.setBorderTop(HSSFCellStyle.BORDER_THIN);
            final HSSFDataFormat df = wb.createDataFormat();  // 此处设置数据格式
            cellStyle.setDataFormat(df.getFormat("#,#0.0")); // 小数点后保留两位,可以写contentStyle.setDataFormat(df.getFormat("#,#0.00"));
            // 声明列对象
            HSSFCell cell = null;

            // 创建标题
            JsonArray cellArray = new JsonArray();
            JsonObject object = new JsonObject();
            JsonObject temobj = new JsonObject();
            int rowSkip = 0, cellSkip = 0;

            String tempCell = "";
            for (int rowId = 0; rowId < title.size(); rowId++) {
                row = sheet.createRow(rowId);
                object = title.get(rowId).getAsJsonObject();
                cellArray = object.get("row").getAsJsonArray();

                // colId为excel列索引,cellId为行标题值的数组索引,cellId遇到当前单元格已使用时,填充至下一个可使用的单元格
                for (int colId = 0, cellId = 0; cellId < cellArray.size(); colId++) {
                    cell = row.createCell(colId);
                    cell.setCellStyle(headerStyle);

                    if (isMergedRegion(sheet, rowId, colId)) {
                        continue;
                    }
                    temobj = cellArray.get(cellId).getAsJsonObject();
                    tempCell = temobj.get("cellvalue").toString().replace("\"", "");
                    try {
                        // System.out.println(tempCell);
                        tempCell = new String(tempCell.getBytes("UTF-8"), "ISO-8859-1");
                        // System.out.println(tempCell);
                        tempCell = new String(tempCell.getBytes("ISO-8859-1"), "UTF-8");
                        // System.out.println(tempCell);
                    } catch (final Exception e) {
                        e.printStackTrace();
                    }
                    cell.setCellValue(tempCell);
                    // System.out.println(cell);
                    // System.out.println(cell.getStringCellValue());
                    cell.setCellStyle(headerStyle);
                    cellId++;

                    // 合并单元格
                    rowSkip = temobj.get("rowspan").getAsInt();
                    cellSkip = temobj.get("colspan").getAsInt();
                    // System.out.println(rowSkip + "=skip==" + cellSkip);
                    if (rowSkip > 1 && rowSkip-- > 0 || cellSkip > 1 && cellSkip-- > 0) {// 用于起始行列计算时需减1
                        final CellRangeAddress cra = new CellRangeAddress(rowId, rowId + rowSkip,
                                colId, colId + cellSkip); // 起始行, 终止行, 起始列, 终止列 // 终止行,
                        sheet.addMergedRegion(cra);
                    }
                }
            }
            // 创建内容 -个sheet只能存65536条
            for (int i = 0; i < 60000 && i < values.length - (n - 1) * 60000; i++) {
                row = sheet.createRow(title.size() + i);
                for (int j = 0; j < values[i].length; j++) {
                    // 将内容按顺序赋给对应的列对象
                    cell = row.createCell(j);
                    cell.setCellValue(values[(n - 1) * 60000 + i][j]);
                    cell.setCellStyle(cellStyle);

                }
            }
        }
        return wb;
    }

    public static boolean isMergedRegion(HSSFSheet sheet, int row, int column) {
        final int sheetMergeCount = sheet.getNumMergedRegions();
        for (int i = 0; i < sheetMergeCount; i++) {
            final CellRangeAddress range = sheet.getMergedRegion(i);
            final int firstColumn = range.getFirstColumn();
            final int lastColumn = range.getLastColumn();
            final int firstRow = range.getFirstRow();
            final int lastRow = range.getLastRow();
            if (row >= firstRow && row <= lastRow) {
                if (column >= firstColumn && column <= lastColumn) {
                    return true;
                }
            }
        }
        return false;
    }
}

 

posted on 2018-10-18 11:46  pu20065226  阅读(7233)  评论(2编辑  收藏  举报