小编典典

使用POI HSSF出错

java

尝试使用MS Office
2003打开Excel工作表时出现错误。此Excel工作表是使用HSSFWorkbook创建的,实现了用户模型范围org.apache.poi.hssf.usermodel

在Microsoft Excel 2003中:“太多不同的单元格格式”。在Microsoft Excel
2007/2010中,文件可能会产生以下错误消息:“ Excel在文件中发现了不可读的内容”。这与单元格格式有关,请参阅以下页面:

http://support.microsoft.com/kb/213904

那么如何在代码中解决此问题?


阅读 220

收藏
2020-11-30

共1个答案

小编典典

Excel限制了您可以使用的不同单元格样式的数量,而且该数量非常少。对于刚接触POI的人们来说,一个普遍的问题是他们跳过了有关工作簿范围内的单元格样式的知识,而改为为每个单元格创建一个单元格样式。这很快使它们超过了Excel中的限制…

您以前编写代码的地方可能看起来像

Sheet s = wb.createSheet();
for (int rn=0; rn<=10; rn++) {
    Row r = s.createRow(rn);
    for (int cn=0; cn<=4; cn++) {
        Cell c = r.createCell(c);
        c.setCellValue( getMyCellValue(rn,cn) );

        CellStyle cs = wb.createCellStyle();
        cs.setBold(true);
        if (cn == 2) { 
            cs.setDataFormat( DataFormat.getFormat(yyyy/mm/dd) );
        }
        c.setCellStyle(cs);
    }
}

相反,您需要将单元格样式创建从头开始,例如

CellStyle bold = wb.createCellStyle();
bold.setBold(true);

CellStyle boldDate = wb.createCellStyle();
boldDate.setBold(true);
boldDate.setDataFormat( DataFormat.getFormat(yyyy/mm/dd) );

Sheet s = wb.createSheet();
for (int rn=0; rn<=10; rn++) {
    Row r = s.createRow(rn);
    for (int cn=0; cn<=4; cn++) {
        Cell c = r.createCell(c);
        c.setCellValue( getMyCellValue(rn,cn) );

        CellStyle cs = bold;
        if (cn == 2) { 
            cs = boldDate;
        }
        c.setCellStyle(cs);
    }
}
2020-11-30