Чтение нескольких листов Excel - PullRequest
0 голосов
/ 19 мая 2011

Я пытаюсь читать листы простыни, используя петлю. Я хотел бы знать, является ли это правильным способом чтения, особенно использования Sheet Propety [выделено в коде]:

Cell[][] newcell=new Cell[200][200];   
int newsheet = workbook1.getNumberOfSheets();
for (int q=1;q < newsheet;q++)    
{
    for(int p=0;p < sheet(q).getColumns();p++)
    {
         for(int p1=0;p1<sheet(q).getRows();p1++)
                       /*^^^^^^^^^*/
         {
               newcell[p][p1] = sheet(q).getCell(p, p1);
                              /*^^^^^^^^^*/
               if(newcell[p][p1].equals(saved[j]))
               {
                    System.out.print( newcell[p][0]);
                }
          }
     }   
}

Могу ли я использовать свойство sheet () в качестве sheet (q), потому что оно выбрасывает NullPointerExeption?

Ответы [ 2 ]

3 голосов
/ 19 мая 2011

Обычный стиль работы со всеми ячейками в POI:

for(int sheetNum=0; sheetNum < wb.getNumberOfSheets(); sheetNum++) {
    Sheet sheet = wb.getSheetAt(sheetNum);
    for (Row row : sheet) {
        for (Cell cell : row) {
            // Do something here
        }
    }
}

Может быть, переключить ваш код на что-то более подобное?

0 голосов
/ 19 мая 2011

С jxl ( JExcelAPI ) это должно работать:

for (Sheet sheet:workbook1.getSheets()) {  // getSheet() returns a Sheet[]
  int numCols = sheet.getColumns();        // getColumns() returns an int
  for(for int i = 0; i <= numCols; i++) {
     Cell[] column = sheet.getColumn(i);
     for(Cell cell:column) {               // column is a Cell[]
        if(cell.equals(saved[j])) {
           System.out.print(cell);
        }
     }
  }   
}
...