0

我正在尝试使用 POI 和 hashMaps 编写一个 excel 表。我的代码成功创建并填充了一个 Excel 工作表,但并非所有信息都写入工作表。在调试模式下,它似乎写入了 5 个键值对,然后循环到键 [0] 的开头。有人能告诉我逻辑中的错误在哪里吗?

HSSFWorkbook workbook = new HSSFWorkbook();
        HSSFSheet sheet = workbook.createSheet(make + " sheet");
        int rowNum = 0;
        ConcurrentHashMap <Integer, String[] > data = new 
                        ConcurrentHashMap<Integer, String[]>();

        data.put(rowNum++, new String[] {"VIN", "Make", "Model", "Year", 
                        "Major Group", "Caption", "Cap Filter", "Illustration",
                        "Illus Filter", "PNC", "Part Name", "Part Number", "Quantity",
                        "Part Filter"});

        for (Part p : plist){
            String PNC = p.getPNC();
            String quantity = p.getQuantity();

            if(vFilterId.contains(p.getId())) {
                data.put(rowNum++ , new String[] {vinId, make, 
                                    model, year, group, caption, capFilter, illusName,
                                    iFilter, PNC, p.getName(), p.getPartNumber(), 
                                    quantity, "NONFILTERED"});

            } else {
                data.put(rowNum++ , new String[] {vinId, make, 
                                    model, year, group, caption, capFilter, illusName,
                                    iFilter, PNC, p.getName(), p.getPartNumber(), 
                                    quantity, "NONFILTERED"});

            }

        }
        int rowIndex = 0;
        Set<Integer> keyset = data.keySet();
        for (Integer key : keyset) {
            Row row = sheet.createRow(rowIndex++);
            Object[] objArr = data.get(key);
            int cellIndex = 0;
            for (Object obj : objArr) {
                Cell cell = row.createCell(cellIndex++);
                cell.setCellValue((String) obj);
            }

        }

        try {
            FileOutputStream fos = new FileOutputStream(outputFile);
            workbook.write(fos);
            fos.close();
            System.out.println("XLS sheet written.");
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
    return ReturnConstants.SUCCESS;
}

提前致谢!

4

2 回答 2

0

您正在使用地图来存储表示表中行的数据。您最好使用列表,因为地图通常不会排序(即条目的顺序可能会随着时间而改变)。

HSSFWorkbook workbook = new HSSFWorkbook();
HSSFSheet sheet = workbook.createSheet(make + " sheet");
List<String[]> data = new ArrayList<String[]>();

data.add(new String[] {"VIN", "Make", "Model", "Year", 
        "Major Group", "Caption", "Cap Filter", "Illustration",
        "Illus Filter", "PNC", "Part Name", "Part Number", "Quantity",
"Part Filter"});

for (Part p : plist){
    String PNC = p.getPNC();
    String quantity = p.getQuantity();

    if(vFilterId.contains(p.getId())) {
        data.add(new String[] {vinId, make, 
                model, year, group, caption, capFilter, illusName,
                iFilter, PNC, p.getName(), p.getPartNumber(), 
                quantity, "NONFILTERED"});

    } else {
        data.add(new String[] {vinId, make, 
                model, year, group, caption, capFilter, illusName,
                iFilter, PNC, p.getName(), p.getPartNumber(), 
                quantity, "NONFILTERED"});

    }

}
for (int rowIndex=0; rowIndex<data.size(); rowIndex++) {
    Row row = sheet.createRow(rowIndex);
    Object[] objArr = data.get(rowIndex);
    int cellIndex = 0;
    for (Object obj : objArr) {
        Cell cell = row.createCell(cellIndex++);
        cell.setCellValue((String) obj);
    }
}
于 2013-07-19T16:08:46.657 回答
0

如果不调试代码很难确定,但从您的描述来看,您的 keyset 变量似乎只包含 3 个条目,这就是为什么您只输出 3 行。所以我要做的第一件事是显示(使用 System.out.println)data.size() 和 keyset.size() 以查看它们有多大。我猜一个或两个都只有 3 号。

您是否显示了所有相关代码?我认为可能不是,因为例如,您的 if 语句似乎是多余的,因为无论您执行 if 代码还是 else 子句,您都输出相同的内容。

我同意第一个答案,即不需要使用 HashMap;ArrayList 也可以。但是,正如您所发现的,这与您只看到 3 行的原因无关。

抱歉,我无法提供更多帮助,但我认为您使用 System.out.println 进行的一些调试将有助于发现问题所在。

于 2013-07-19T18:20:28.130 回答