在Apache POI中设置样式

时间:2017-04-18 08:27:35

标签: java excel apache-poi

我正在为标题设置样式,我最后一列的其中一个也得到了我为标题设置的样式。这是我设置设置样式的代码。

        XSSFWorkbook workbook = new XSSFWorkbook();
    XSSFSheet sheet = workbook.createSheet(sheetName);

    for (int i = 0; i < numberOfMergedRow; i++) {
        sheet.addMergedRegion(new CellRangeAddress(i, i, 0, numberOfColumns - 1));
        sheet.autoSizeColumn(i);
    }

    XSSFRow row = sheet.createRow(0);
    int l = row.getLastCellNum() + 1;
    XSSFCell cell = row.createCell((short) l);
    XSSFCellStyle cellStyle = workbook.createCellStyle();
    Font headerFont = workbook.createFont();

    Set<Integer> keyset = data.keySet();
    int rownum = 0;
    for (Integer key : keyset) {
        row = sheet.createRow(rownum++);
        Object[] objArr = data.get(key);
        int cellnum = 0;
        for (Object obj : objArr) {
            cell = row.createCell(cellnum++);
            if (obj instanceof String)
                cell.setCellValue((String) obj);
            else if (obj instanceof Integer)
                cell.setCellValue((Integer) obj);
            else if (obj instanceof Double)
                cell.setCellValue((Double) obj);
            else if (obj instanceof Number)
                cell.setCellValue((Double) obj);
        }

        cellStyle.setAlignment(XSSFCellStyle.ALIGN_CENTER);
        cellStyle.setVerticalAlignment(XSSFCellStyle.VERTICAL_CENTER);

        /* adding heading style */
        cellStyle.setFillForegroundColor(IndexedColors.LIGHT_CORNFLOWER_BLUE.getIndex());
        cellStyle.setFillPattern(CellStyle.SOLID_FOREGROUND);
        headerFont.setBoldweight(Font.BOLDWEIGHT_BOLD);

        headerFont.setFontHeightInPoints((short) 12);
        cellStyle.setFont(headerFont);

        cell.setCellStyle(cellStyle);

my output

我怎样才能在标题中设置样式?

1 个答案:

答案 0 :(得分:1)

XSSFWorkbook workbook = new XSSFWorkbook();
XSSFSheet sheet = workbook.createSheet(sheetName);
for (int i = 0; i < numberOfMergedRow; i++) {
    sheet.addMergedRegion(new CellRangeAddress(i, i, 0, numberOfColumns - 1));
    sheet.autoSizeColumn(i);
}

XSSFRow row = sheet.createRow(0);
int l = row.getLastCellNum() + 1;
XSSFCell cell = row.createCell((short) l);
XSSFCellStyle cellStyle = workbook.createCellStyle();
Font headerFont = workbook.createFont();

cellStyle.setAlignment(XSSFCellStyle.ALIGN_CENTER);
cellStyle.setVerticalAlignment(XSSFCellStyle.VERTICAL_CENTER);

/* adding heading style */
cellStyle.setFillForegroundColor(IndexedColors.LIGHT_CORNFLOWER_BLUE.getIndex());
cellStyle.setFillPattern(CellStyle.SOLID_FOREGROUND);
headerFont.setBoldweight(Font.BOLDWEIGHT_BOLD);

headerFont.setFontHeightInPoints((short) 12);
cellStyle.setFont(headerFont);

cell.setCellStyle(cellStyle);

Set<Integer> keyset = data.keySet();
int rownum = 0;
for (Integer key : keyset) {
    row = sheet.createRow(rownum++);
    Object[] objArr = data.get(key);
    int cellnum = 0;
    for (Object obj : objArr) {
        cell = row.createCell(cellnum++);
        if (obj instanceof String)
            cell.setCellValue((String) obj);
        else if (obj instanceof Integer)
            cell.setCellValue((Integer) obj);
        else if (obj instanceof Double)
            cell.setCellValue((Double) obj);
        else if (obj instanceof Number)
            cell.setCellValue((Double) obj);
    }

将cellStyle代码移到for循环之外