在标记为重复之前,请先阅读全文。我已经看过所有相关/相似的问题,我想我这里发生了一些奇怪的事情。
我正在使用Apache POI版本3.9生成一个4页的工作簿。每次填完工作表时,我都会自动调整列的大小。这是代码:
for (String alias : map.keySet()) {
Sheet sheet = workbook.createSheet(getSheetNameForAlias(alias));
List<Object[]> resultList = (List<Object[]>) map.get(alias);
Collections.sort(resultList.subList(1, resultList.size()), getComparator(alias));
int rownum = 0;
for (Object[] array : resultList) {
rownum = populateRow(cellStyles, sheet, rownum, array, false);
}
for(int j=0; j< resultList.get(0).length; j++){
sheet.autoSizeColumn(j, false);
}
}
populateRow函数为:
private int populateRow(CellStyle[] cellStyles, Sheet sheet, int rownum, Object[] dataArr, boolean doAutoSizing) {
if (logger.isDebugEnabled()) {
logger.debug("Populating row ... @{} : {} ", sheet.getSheetName(), rownum);
}
int cellnum;
Row row = sheet.createRow(rownum++);
cellnum = 0;
if (ArrayUtils.isEmpty(dataArr)) {
logger.error("No data found for row ... @{} : {} ", sheet.getSheetName(), rownum);
return rownum;
}
for (Object obj : dataArr) {
Cell cell = row.createCell(cellnum++);
// get the type of the data inserted in the cell.
// Accordingly set the cell value
String data = String.valueOf(obj);
if (StringUtils.isBlank(data) || "null".equals(data)) {
cell.setCellValue(StringUtils.EMPTY);
} else {
if (NumberUtils.isNumber(data)) {
Double dbVal = NumberUtils.createDouble(data);
// Millions separator for Numeric fields
if (dbVal == Math.ceil(dbVal)) {
cell.setCellStyle(cellStyles[0]);
} else {
cell.setCellStyle(cellStyles[1]);
}
cell.setCellType(Cell.CELL_TYPE_NUMERIC); // for numeric , set cell type as numeric
cell.setCellValue(dbVal);
} else {
if(obj instanceof java.sql.Timestamp || obj instanceof java.sql.Date){
cell.setCellStyle(cellStyles[2]);
}
cell.setCellValue(data);
}
if (doAutoSizing) {
sheet.autoSizeColumn(cellnum - 1);
}
data = null;
}
obj = null;
}
return rownum;
}
奇怪的是,四张纸中的一张纸的列大小调整不正确。
我尝试用不同的方法重新编写
auto size
逻辑,然后发现工作表上出现了我的这种错误行为,如果我尝试使用sheet.getRow(0)
,则会给出null
,指明存在该行没有数据,但是生成的excel不能满足要求,所有四张纸都具有适当的数据。而且在每种情况下,第一行始终是标题,因此即使其下面没有数据,也不能为null。我不知道我缺少什么,但是我尝试过发现它不是JVM的Font问题。
如果您需要其他信息,请告诉我。
编辑:观察到自动调整大小对于有100多行的工作表是不正确的。我不知道如何将其与某些逻辑联系起来。这是真正的怪异。
编辑2:我在寻找其他东西时找到了Axel给出的正式参考。这足以使我感到困惑。阅读以下内容
link
最佳答案
由于您说它最多可以处理100行,因此您似乎在使用SXSSFWorkbook
,而不是XSSFWorkbook
。然后,必须预期这种行为,因为内存中仅保留固定数量的行,并且仅考虑这些行。因此,如果我是对的,您将不得不切换到使用XSSFWorkbook
(前提是这在处理大量行时不会导致OOM)。