如何使用相应的行和列格式化Java ArrayList并调用列或行的数据?

时间:2018-06-05 10:28:32

标签: java arrays csv arraylist

我是Java初学者,我一直在尝试使用Java从我的计算机读取csv文件并将数据插入到ArrayList中。

public class DataRepository {

public void loadFile(){
    ArrayList<String> binsGrade = new ArrayList<String>();
    try {
        Scanner fileScanner = new Scanner(new File("C:\\Users\\Max\\Desktop\\Grade_SampleData.csv"));
        while(fileScanner.hasNextLine()){

            binsGrade.add(fileScanner.nextLine());
        }

        fileScanner.close();

        System.out.println(binsGrade);


    } catch (FileNotFoundException e){
        e.printStackTrace();
    }
}
}

以下是我得到的结果:

[name,literature,math,physics,chemistry,biology,history,geology,art,sports, Michael,80,90,82,79,75,70,72,68,95, Amy,85,88,73,79,88,93,90,92,75, Johnson,72,89,81,84,83,72,89,90,82, Bob,80,81,84,89,87,90,71,65,89, Tommy,70,89,79,90,88,73,75,89,91, Rachel,90,91,80,92,87,92,95,97,87, Evonne,78,91,87,88,91,76,74,86,91]

所有记录都在一行中,但我实际上希望它在分开的行和列中,例如,当我调用name时,我可以得到值:Michael,Amy,Johson等。当我打电话时文献,我可以得到80,85,72,80等。然后我可以用这些数据做一些计算,比如计算平均值,或者得到最高分等等。

虽然我已经在线搜索了一段时间,但我仍然没有想出实现这一目标的最佳方法。如果你有一分钟​​的话,请你分享一下你的想法吗?非常感谢您的帮助。谢谢!

1 个答案:

答案 0 :(得分:1)

如果您希望快速实施某些内容,可以关注Srivenu comment并使用Map<String, List<String>>。 Map的每个条目都有名称作为键,以及所有结果的字符串列表。例如,添加迈克尔:

myMap.add("Michael", Arrays.asList({"20", "12", "8", "80"}));

然后创建将通过此地图计算平均值的不同方法,或者找到最大值等

如果您想要更面向对象的方法,我建议您创建代表您的数据的对象。首先是一个结果对象,它将包含两个属性,一个将成为主语的字符串和一个将成为分数的int。

public class Result {
    private String subject;
    private int score;

    public Result(String s, int i) {
        subject = s;
        score = i;
    }

    //Add Setters and Getters
    //Add additional method if required
}

其次有一个代表某人的人物。它将有两个属性,一个表示名称的String和一个Results对象列表。

public class Person {
    private String name;
    private List<Result> results;

    public Person(String s, List<Result> r) {
        name = s;
        results = r;
    }

    //Add getters and setters
    //Add additional methods if required

    /**
     * Example of additional method
     * This one will return the score for a given subject
    **/
    public int getScore(String subject) {
        Result r = results.get(subject);
        return r.getScore();
    }

}

第三,创建一个GroupOfPerson类,它将包含一个属性,一个人员列表。然后这个类将有返回平均值,最大值等的方法......

public class GroupOfPerson {
    private List<Person> persons;

    public GroupOfPErson(List<Person> p) {
        persons = p;
    }

    /**
     * Example of method.
     * This one will return the average score for the given subject
    **/
    public int getAverageForSubject(String subject) {
        int average = 0;
        for(Person p : persons) {
            average += p.getScore(subject);
        }
        average /= persons.size();
        return average;
    }

    //Add other methods
}

最后,在阅读CSV文件时,请创建相应的对象。