![](/img/trans.png)
[英]java.lang.UnsupportedOperationException with ArrayList()
[英]java.lang.UnsupportedOperationException: null
我正在尝试删除 apache-poi 中的空单元格。 我在 unmarkedColumns.remove(unmarkedColumns.get(i)) 收到此错误:删除方法存在问题。 我不明白为什么。你能帮我吗?
java.lang.UnsupportedOperationException: null
at java.util.AbstractList.remove(Unknown Source)
at java.util.AbstractList$Itr.remove(Unknown Source)
)
Integer[] integers = new Integer[headers.size()];
Arrays.fill(integers, 0);
List<Integer> unmarkedColumns = Arrays.asList(integers);
for (ScoredFormData scoredFormData : scoredFormDatas) {
Row dataRow = sheet.createRow(++rownum);
List<Object> rowValues = prepareExportRow(scoredFormData, visitManager, parameters,
dynamicDatamanager,
scoreCriteriaDefinitions);
for (int i = 0; i < rowValues.size(); i++) {
if (unmarkedColumns.get(i) != 1 && rowValues.get(i) != null
&& !rowValues.get(i).equals("")) {
unmarkedColumns.set(i, 1);
}
}
populateCells(rowValues, dataRow);
}
for (int i = 0; i < unmarkedColumns.size(); i++) {
if (unmarkedColumns.get(i) == 0) {
Iterator<Row> rowIterator = sheet.iterator();
while (rowIterator.hasNext()) {
Row row = rowIterator.next();
Boolean changed = false;
for (int j = i + 1; j < row.getLastCellNum() + 1; j++) {
Cell oldCell = row.getCell(j - 1);
if (oldCell != null) {
row.removeCell(oldCell);
changed = true;
Cell nextCell = row.getCell(j);
if (nextCell != null) {
Cell newCell = row.createCell(j - 1, nextCell.getCellType());
switch (newCell.getCellType()) {
case Cell.CELL_TYPE_BOOLEAN: {
newCell.setCellValue(nextCell.getBooleanCellValue());
break;}}}}
if (changed ) {
unmarkedColumns.remove(unmarkedColumns.get(i));
i = 0;
}
}
Arrays.asList(..)
返回一个大小固定的 List,所以你不能扩大或缩小它。
要修复它,您可以将其包装在ArrayList
中:
List<Integer> unmarkedColumns = new ArrayList<>(Arrays.asList(integers));
你的问题在这里
List<Integer> unmarkedColumns = Arrays.asList(integers);
如果您使用 Arrays.asList(...),它会返回一个固定大小的列表,因此您不能从中删除元素。
您可以通过包装它来解决问题:
List<Integer> list = new ArrayList<Integer>(Arrays.asList(integers));
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.