-3

我已经成功地将XLS工作表读取到ArrayList。现在棘手的部分是,我试图将其映射到固定的二维数组。分别为i = 1705x = 155y = 11将数组列表转换为固定的二维数组并打印?

编辑:也许我没有明确的问题部分所述。 我试图将下面提到的Excel(Book1.xls)的元素复制到二维数组中。到目前为止,我已经成功将ti复制到arraylist中:“singleRows”。但我无法将它们移动到二维数组:“myReplicate”。

我想使用此数组的元素来创建SQL插入语句。 希望我没有错过任何指定要求。

package excelread3; 

import java.io.File; 
import java.io.FileInputStream; 
import java.io.IOException; 
import java.text.SimpleDateFormat; 
import java.util.ArrayList; 
import java.util.Iterator; 
import java.util.List; 
import java.util.stream.Stream; 
import org.apache.poi.ss.usermodel.Cell; 
import org.apache.poi.ss.usermodel.DateUtil; 
import org.apache.poi.ss.usermodel.Row; 
import org.apache.poi.xssf.usermodel.XSSFSheet; 
import org.apache.poi.xssf.usermodel.XSSFWorkbook; 
import org.apache.poi.hssf.usermodel.HSSFWorkbook; 
import org.apache.poi.hssf.usermodel.HSSFSheet; 
import org.apache.poi.hssf.usermodel.HSSFRow; 
import org.apache.poi.hssf.usermodel.HSSFCell; 

public class ExcelRead3 
{ 
    public static void main(String[] args) throws IOException 
    { 
     FileInputStream file = new FileInputStream(new File("C:\\Users\\CReaper\\Documents\\docs\\Opice\\Book1.xls")); 
     HSSFWorkbook wb = new HSSFWorkbook(file); 
     HSSFSheet sheet = wb.getSheetAt(0); 
     HSSFRow firstRow = sheet.getRow(0); 
     int rowcount = sheet.getPhysicalNumberOfRows(); 
     int colcount = firstRow.getLastCellNum(); 
     Iterator<Row> rowIterator = sheet.iterator(); 
     ArrayList<Object> singleRows = new ArrayList<Object>(); 
     ArrayList<Object> list = new ArrayList<Object>(); 
     while (rowIterator.hasNext()) 
     { 
      Row row = rowIterator.next(); 
      Iterator <Cell> cellIterator = row.cellIterator(); 
      for(int i =1 ; i < colcount ; i++) 
      { 
       while (cellIterator.hasNext()) 
       { 
        Cell cell = cellIterator.next(); 
        //System.out.print(cell.getStringCellValue() + "\t\t"); 
        singleRows.add(cell.getStringCellValue()); 
       } 
      } 
      list.add(singleRows); 
     } 
     // System.out.println(rowcount + "\n"); 
     // System.out.println(colcount + "\n"); 
     Stream<Object> stringStream; 
     stringStream = singleRows.stream(); 
     String[][] myReplicate = new String[rowcount][colcount]; 
     myReplicate = stringStream.toArray(new String[stringStream.size()]); 
     for (int i = 0; i < rowcount; i++) 
     { 
      for(int j = 0; j < colcount; j++) 
      { 
       System.out.printf("%5d ", myReplicate[i][j]); 
      } 
      System.out.println(); 
     } 
     file.close(); 
    } 
} 

我想在填充数组元素之前将ArrayList转换为流。

+2

为什么代码中的每一行都是注释?另外,回避机制并解释你想要达成的目标。这个问题目前还不清楚,很可能会被低估并搁置。 –

+0

你好,这是我第一次尝试插入代码到stackoverflow,它一直说我的代码没有正确格式化,直到我评论每一行(Ctrl + K)..我在这里试图做的是将excel映射到二维数组,然后为sql插入语句创建案例。 – Manjunath16

回答

0

刚刚检查过将Excel映射到二维数组。 并发现这个:

 String[][] excelData = new String[numRows][numCols]; 
     for (int i=0; i<numRows; i++) 
       { 
       HSSFRow row = mySheet.getRow(i); 
       for (int j=0; j<numCols; j++) 
        { 
        HSSFCell cell = row.getCell(j); 
        String value = cell.getStringCellValue(); 
        excelData[i][j] = value; 
        System.out.println(Arrays.deepToString(excelData));  
        } 
       System.out.println(); 
       }  
        } 
       System.out.println(); 
       } 

这帮助我进一步我的要求。 感谢您的关注。