gpt4 book ai didi

java - Apache POI autoSizeColumn() 行为怪异

转载 作者:行者123 更新时间:2023-12-01 11:54:11 26 4
gpt4 key购买 nike

在标记为重复之前,请先阅读全文。我已经看到了所有相关/类似的问题,我想我这里发生了一些奇怪的事情。

我正在使用 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 不符合这一点,所有四个工作表都有适当的数据。在每种情况下,第一行始终是标题,因此即使下面没有数据,它也不可能为空。

我不知道我错过了什么,但我尝试发现这不是 JVM 的字体问题。

如果您需要其他信息,请告诉我。

编辑:观察到,对于超过 100 行的工作表,自动调整大小工作不正常。我不知道如何将其与某些逻辑联系起来。这真的很奇怪。

编辑2:我在寻找其他东西时找到了Axel给出的原因的官方引用。这确实足以满足我的困惑。阅读以下段落 link

最佳答案

既然你说它最多可以处理 100 行,那么看起来你正在使用 SXSSFWorkbook ,不是XSSFWorkbook 。那么这种行为是可以预料到的,因为内存中只保存了固定数量的行,并且只有这些行才会被考虑。因此,如果我是对的,您将不得不改用 XSSFWorkbook(前提是在处理大量行时这不会导致 OOM)。

关于java - Apache POI autoSizeColumn() 行为怪异,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28564045/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com