我需要从csv文件中读取数据,并且将更方便的数据放到2D数组中(我的脑海里最容易使用此“时间表”数据) 。 每个文件的行包含在以下格式的信息:从csv文件中提取数据并将其放入2D数组 - 重构
Instructor, Course, Group, Student, Result
如下例子:
Paul Schwartz,Introduction to Computer Architecture,I1,Ben Dunkin,88
Muhamed Olji,Object Oriented Programming,I4,Mike Brown,73
但我的代码需要一些简化。但我不知道如何使它更容易,并要求你。
代码:
private String[][] fileContent(String pathToCSVFile) {
final int ROWS = 100;
final int COLUMNS = 5;
String fileData[][] = new String[ROWS][COLUMNS];
Scanner scanner = new Scanner(pathToCSVFile);
boolean done = false;
int i, j;
while (!done) {
for (i = 0; i >= 0; i++) {
for (j = 0; j >= 0; j++) {
String str[] = scanner.nextLine().split(",");
for (int element = 0; element < str.length; element++) {
fileData[i][element] = str[element];
if (i >= ROWS) {
Arrays.copyOf(fileData, fileData.length * 2);
}
}
}
}
if (!scanner.hasNextLine()) done = true;
}
return fileData;
}
- 如何重构此代码段为更好的简单?
- 对于部分填充的数组是否存在更好的方法(比
Arrays.copyOf(fileData, fileData.length * 2)
)?
如果简单是你的目标,使用CSV库,如openCSV,它有一个'列表 lines = new CSVReader(reader).readAll();'方法...然后你的方法成为一线(可能两个)。 –
assylias
请考虑在http://codereview.stackexchange.com/上发布此类问题。该网站应该更合适。 –
@assylias我[尝试这种方式](http://pastebin.com/sfizSsuc)但从List转换为数组有点问题。任何建议也可以在这里找到。 –