使用java处理多个csv行

时间:2018-02-09 09:44:22

标签: java csv for-loop collections

我有一个文件,我在一个新行中写了一个csv值。结果看起来很像:

Hello;kind;world
Mister;John;Doe

等等。我也有一个带有构造函数的类,它取每个部分值,例如: John作为参数:

public MyClass(String first, String second, String third) {}

因此我需要一个Collection<MyClass>。处理I迭代每个csv行,然后在特定行值的内部for循环之后用;分割它:

Collection<String> csvLines = Files.readAllLines(pathToMyFile);
for (String csvLine : csvLines) {
 String[] csvLineSplitted = csvLine.split(";");
 for (int i = 0; i < csvLineSplitted.length; i++) {
  String value = scvLineSPlitted[i]; //This can be the above mentioned value, e.g. 'John'
 }
}

如何使用每个特定参数创建MyClass类型的对象,然后将其存储在Collection<MyCLass> result

2 个答案:

答案 0 :(得分:2)

只需定义一个类:

public class MyClass {
    private String param1;
    private String param2;

    public MyClass(String param1, String param2) {
        this.param1 = param1;
        this.param2 = param2;
    }

    // getters and setters
}

然后在迭代CSV数据时使用该类:

Collection<String> csvLines = Files.readAllLines(pathToMyFile);
List<MyClass> list = new ArrayList<>();
for (String csvLine : csvLines) {
    String[] csvLineSplitted = csvLine.split(";");
    MyClass node = new MyClass(csvLineSplitted[0], csvLineSplitted[1]);
    list.add(node);
}

请注意,我假设您的数据只有两列。如果实际数据有多列,那么在for循环中迭代的方法更有意义。

答案 1 :(得分:1)

您也可以使用 Streams 实现此目的:

sed_pattern

如果您有两列以上,只需修改第二个地图运算符以满足您的要求