2012-03-31 146 views
0

我正在寫一個應用程序,它從Microsoft Access數據庫讀取數據並將此數據寫入Excel工作表。一切正常,但不是將新數據寫入文件。這裏是代碼:用apache poi從Java寫入Excel文件

private static XSSFWorkbook readFile(String filename) throws IOException { 
    // return new XSSFWorkbook(new FileInputStream(filename)); 
    InputStream inp = new FileInputStream(filename); 
    XSSFWorkbook wb = null; 
    try { 
     wb = (XSSFWorkbook) WorkbookFactory.create(inp); 
    } catch (InvalidFormatException e) { 
     // TODO Auto-generated catch block 
     e.printStackTrace(); 
    } 
    return wb; 
} 

public void writeToFile(LinkedList<TimeRowWrapper> list) { 

    try { 
     // read file 
     XSSFWorkbook workbook = readFile(fileName); 

     // choose table from index 
     XSSFSheet sheet = workbook.getSheetAt(kapaSheetIndex); 

     for (Row row : sheet) { 
      int rowNum = row.getRowNum(); 

      // iterate over list for row id 
      for (TimeRowWrapper trw : list) { 
       if (rowNum == trw.getRowNumber()) { 

        double hour = Math 
          .round(trw.getTotalTime()/60.0 * 100.)/100.; 
        Cell cell = row.getCell(timeCol); 
        cell.setCellValue(hour); 
       } 
      } 
     } 

     XSSFFormulaEvaluator.evaluateAllFormulaCells(workbook); 

     FileOutputStream out = new FileOutputStream(fileName); 
     workbook.write(out); 
     out.close(); 

    } catch (IOException e) { 
     e.printStackTrace(); 
    } catch (NullPointerException e) { 
     e.printStackTrace(); 
    } catch (NumberFormatException e) { 
     e.printStackTrace(); 
    } 
} 
+0

如果條件不成立? – Jayan 2012-03-31 10:45:22

+0

您的Excel表格是否已包含要寫入的行和列?如果沒有,調用getRow()和getCell()將無處可去,因爲它們將返回null。或者因爲您依賴HSSFSheet的Iterable接口,我認爲它將有零迭代。嘗試迭代你的模型列表,並調用createRow()和createCell()。 – nansen 2012-03-31 10:49:37

+0

if條件成立。一切工作正常在每個循環。 Excel文件包含我想要寫入數據的行和列。 – krains 2012-03-31 11:20:53

回答

0

我發佈的源代碼是正確的。在Excelfile中有一些Colums與0相似 - 所以我試着寫在一個沒有顯示的列中。

0

從你對你的帖子的評論,我假設你在for循環中所做的是正確的。看起來你正在寫代碼中的數值,而且你還在寫與你閱讀過的相同的工作簿。我有一個理論可能是你正在寫入單元格,但是做公式評估可能會做一些棘手的事情與數字,因爲Excel喜歡格式化的類型奇怪。

嘗試寫入新文件而不是輸入文件,並查看是否至少生成電子表格。

也可以嘗試看到註釋掉線的時候會發生什麼:

XSSFFormulaEvaluator.evaluateAllFormulaCells(workbook);