【问题标题】:Java: Issue With Storing Data from Excel in an ArrayList of ArrayListsJava:将 Excel 中的数据存储在 ArrayList 的 ArrayList 中的问题
【发布时间】:2014-12-22 04:06:21
【问题描述】:

我正在尝试将来自 excel 的数据存储在 ArrayLists 中,然后将其存储在主 ArrayList 中。原因是 excel 表的每一行都有特定于该行的数据。我一直有一个问题,因为我相信当我在循环返回之前擦除内部 ArrayList 时,它也会删除主 ArrayList 中的数据。

import java.io.*;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.usermodel.Workbook;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import java.util.ArrayList;


public class StoreData {

ArrayList<ArrayList<String>> shapes;
ArrayList<String> innerMembers;
ArrayList<String> test;
int start;
int end; 

public StoreData(){
    this.shapes = new ArrayList<>();
    this.innerMembers = new ArrayList<>();
    this.test = new ArrayList<>();
    start = 0;
    end = 0;
}

public ArrayList<ArrayList<String>> storeValues(String shapeType){

    //get the shape
    switch(shapeType){
        case "A":
            start = 1;
            end = 273;
            break;
        case "B":
            start = 274;
            end = 291;
            break;
        case "C":
            start = 292;
            end = 319;
            break;
        case "D":
            start = 320;
            end = 340;
            break;
        case "E":
            start = 341;
            end = 372;
            break;
        case "F":
            start = 373;
            end = 412;
            break;
        case "G":
            start = 413;
            end = 539;
            break;
        case "H":
            start = 540;
            end = 814;
            break;
        case "I":
            start = 1464;
            end = 1958;  
    }

 try
 {
    FileInputStream x = new FileInputStream(new File("/Users/JohnDoe/Documents/File.xls"));

    //Create Workbook instance 
    Workbook workbook = new HSSFWorkbook(x);

    //Get first/desired sheet from the workbook
    Sheet sheet = workbook.getSheetAt(0);

    //Iterate through each rows one by one
    for (int i = start; i <= end; i ++){

        Row row = sheet.getRow(i++);

        //iterate through each cell in row: max number of cells is 76
        for (int j = 0; j < 77; j++) {

            Cell cell = row.getCell(j);
            cell.setCellType(1);
            innerMembers.add(cell.getStringCellValue());
    }            

    /*******************/
    //Add to master ArrayList and clear inner ArrayList to get repopulated
    /*******************/
    shapes.add(innerMembers);
    innerMembers.clear();
}
x.close();
}
catch (Exception e)
{
    e.printStackTrace();
}

/***TEST STATEMENT***/
System.out.println(shapes.get(8).get(20));
/***TEST STATEMENT***/

return shapes;

}
}

【问题讨论】:

  • 每次调用 storeValues 方法时都需要创建一个内部成员的新 ArrayList。形状存储相同的内部成员实例,即当您从数组列表中清除元素时,它会反映形状参考数组列表。

标签: java arraylist apache-poi


【解决方案1】:

你可能想试试:

shapes.add(new ArrayList<String>(innerMembers)); // shallow copy 
innerMembers.clear();

【讨论】:

    猜你喜欢
    • 2013-09-04
    • 2013-12-17
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2010-12-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多