有 Java 编程相关的问题?

你可以在下面搜索框中键入要查询的问题!

java将arraylist流到固定的二维数组中并打印?

我已经成功地将XLS工作表读到了ArrayList。现在棘手的部分是,我试图将其映射到一个固定的二维数组ArrayList(i) --> Array(x)(y)其中i = 1705x = 155y = 11

编辑:也许我不清楚上面提到的问题。 我试图将下面提到的Excel(Book1.xls)中的元素复制到一个二维数组中。到目前为止,我已经成功地将ti复制到arraylist:“singleRows”。但我很难将它们转移到二维数组:“myReplicate”

我想使用这个数组的元素来创建SQL insert语句。 希望我在说明要求时没有遗漏任何内容

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转换为流


共 (1) 个答案

  1. # 1 楼答案

    刚刚检查了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();
                    }
    

    这帮助我进一步提高了我的要求。 谢谢大家的关注