簡體   English   中英

讀取Excel文件2010 Apache POI忽略空單元格

[英]Read excel file 2010 apache poi ignoring empty cells

我有一個問題,當java應用程序讀取Excel文件.xlsx擴展時,該應用程序正常工作,但是在工作簿中有很多工作表,其中1、2個工作表正確讀取,但是當讀取3個工作表時,沒有讀取所有單元格當我打開並從Excel文件中檢查時,單元格存在空值,但是當apache poi讀取該單元格時,該單元格將被忽略。 原因是什么? 更新

 FileInputStream file = new FileInputStream(file_location);
  //this.workbook = new HSSFWorkbook(file);
  this.workbook = new XSSFWorkbook(file);
XSSFSheet mySheet = workbook.getSheetAt(index);
       Iterator rowIter = mySheet.rowIterator();
        while(rowIter.hasNext()){
          XSSFRow myRow = (XSSFRow) rowIter.next();
          Iterator cellIter = myRow.cellIterator();
          ArrayList colStoreArray=new ArrayList();



          while(cellIter.hasNext()){
              XSSFCell myCell = (XSSFCell) cellIter.next();
              colStoreArray.add(myCell);
                                   }
          rowArrayHolder.add(colStoreArray);

        } }

在讀取excel文件上方,雖然我在一行中檢查了Excel文件20個單元格,但在某些行中卻僅讀取了14行。 我正在使用ArrayList,似乎這里應該是並發訪問ArrayList的問題。 可能是什么原因?

迭代器僅遍歷文件中定義的單元格。 如果單元格從未在Excel中使用過,則它可能不會出現在文件中(Excel並不總是一致的...),因此POI不會看到它

如果要確保擊中每個單元格,則應改用索引查找,然后檢查空單元格(指示該單元格在文件中不存在),或設置MissingCellPolicy來控制希望空單元格和空白單元格被處理

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM