读取fom CSV并将数据存储到ArrayList

时间:2016-12-06 21:33:36

标签: java android csv arraylist opencsv

我正在使用OpenCSV来读取存储在设备内部存储中的CSV文件,\G Shop\Input CSV\名为product.csv。该文件包含一些随机产品名称的列。我想将每个产品存储到ArrayList但我的代码无效。

以下是代码:

String baseDirectory = android.os.Environment.getExternalStorageDirectory().getAbsolutePath();
File readCsvFolder = new File(baseDirectory + File.separator + "G Shop" + File.separator + "Input CSV" + File.separator);
String readFileName;
String readFilePath;
List<String[]> readData;

void readCSV() {
    readCsvFolder.mkdirs();

    readFileName = "products.csv";
    readFilePath = readCsvFolder.getPath() + File.separator + readFileName;
    try {
        ArrayList<String> searchProducts = new ArrayList<>();

        readData = new ArrayList<String[]>();
        CSVReader reader = new CSVReader(new FileReader(readFilePath));
        readData = reader.readAll();

        String[] row;
        while ((row = reader.readNext()) != null) {
            searchProducts.add(row[0]);

            //This Toast never shows up!
            Toast.makeText(mainActContext,"Saved : " + row[0],Toast.LENGTH_SHORT).show();
        }
    } catch (IOException e) {
        e.printStackTrace();
    }
}

我没有看到错误或警告,调用方法后根本没有输出。我非常感谢任何形式的帮助或建议:)

1 个答案:

答案 0 :(得分:2)

readData = reader.readAll();正在读取整个文件输入流,直到文件结束。因此,row = reader.readNext()) != null将不会给你带来任何好处;读者已经到了文件的末尾。相反,您的循环可能只是:for(String[] row:readData)

for(String[] row:readData) {
    searchProducts.add(row[0]);

    //Now the toast shows up!
    Toast.makeText(mainActContext,"Saved : " + row[0],Toast.LENGTH_SHORT).show();
}