如何用各自的行和列格式化Java 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]

所有记录都在一行中,但我实际上希望它在单独的行和列中,例如,当我调用名称时,我可以获取值:迈克尔、艾米、乔森等。当我打电话给文学时,我可以得到80,85,72,80等等。然后我可能会使用这些数据进行一些计算,例如计算平均值,或获得最高分等。

虽然我已经在网上搜索了一段时间,但我仍然没有找到实现这一目标的最佳方法。如果你有一分钟的时间,你能分享你的想法吗?您的帮助将不胜感激。谢谢!

如果你想快速实现一些东西,你可以关注Srivenu评论并使用Map<String, List<String>>。Map 的每个条目都将以名称作为键,以及所有结果的字符串列表。例如,要添加迈克尔:

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

然后创建不同的方法,这些方法将通过此映射来计算平均值,或找到最大值等


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

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
}

其次,有一个代表某人的 Person 对象。它将有两个属性,一个表示名称的字符串和一个结果对象列表。

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 文件时,创建相应的对象。

最新更新