我有一个文本文件:
Jim Webb 27 Axelrod Street
Hillary Sanders 92 California Street
Bernie Trudeau 46 Pot Street
Barack Bush 883 White Ave
Mary Warren 736 Something Rd
Donald Crump 65 Debate Street
我需要解析一个人,first name,last name,address(人姓后面的信息)。
这是我的尝试:
public Parse() {
parseFiles();
}
void parseFiles() {
try {
File file = new File("school.txt");
Scanner sc = new Scanner(file);
while (sc.hasNextLine()) {
String s = sc.nextLine();
String[] splited = s.split("\\s+");
for (int i = 0; i < splited.length; i++) {
System.out.println(splited[i]);
}
}
} catch (FileNotFoundException e) {
System.out.println("File not found\n");
}
}
}
不幸的是,我的方法逐个空格地解析每一行,这适用于名字和姓氏,但不适用于地址,因为我希望地址是一个完整的字符串,而不是一堆字符串以空格隔开。
例如,我有一个这样的学生类:
public Student(String name, String lastName, String address) {
this.name = name
//etc...
}
我每次都想初始化一个学生(在读取每一行之后),但是在我的实现中,我只能对人员的名字和姓氏进行初始化,我将如何单独解析整个地址?然后可以调用 Student Constructor。
最佳答案
您可以使用 .next()
获取名字和姓氏,然后使用 .nextLine()
获取该行的其余部分,例如这个:
String firstName = sc.next();
String lastName = sc.next();
String address = sc.nextLine();
关于java - 拆分文件中的信息并读取它们,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33849923/