-3
我已经成功地将XLS工作表读取到ArrayList
。现在棘手的部分是,我试图将其映射到固定的二维数组。分别为i = 1705
和x = 155
和y = 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转换为流。
为什么代码中的每一行都是注释?另外,回避机制并解释你想要达成的目标。这个问题目前还不清楚,很可能会被低估并搁置。 –
你好,这是我第一次尝试插入代码到stackoverflow,它一直说我的代码没有正确格式化,直到我评论每一行(Ctrl + K)..我在这里试图做的是将excel映射到二维数组,然后为sql插入语句创建案例。 – Manjunath16