我正在尝试使用 java.util.Scanner 读取下面的文本文件。在一个简单的 Java 程序中。
0001;GUAJARA-MIRIM;RO
0002;ALTO ALEGRE DOS PARECIS;RO
0003;PORTO VELHO;RO
我使用下面的代码读取文本文件:
scanner = new Scanner(filerader).useDelimiter("\\;|\\n");
while (scanner.hasNext()) {
int id= scanner.nextInt();
String name = scanner.next();
String code = scanner.next();
System.out.printf(".%s.%s.%d.\n", name, code, id);
}
结果是:
.GUAJARA-MIRIM.RO.1
.
.ALTO ALEGRE DOS PARECIS.RO.2
.
.PORTO VELHO.RO.3
.
但是每行第三个标记的结果末尾有一个不方便的“\r”字符(ANSI 代码 13)。我不知道为什么(我在格式化字符串上使用了“.”字符来明确“\r”在哪里)。
所以,
- 为什么第三个标记末尾有一个“\r”?
- 如何绕过它。
使用像 code.substring(0, 2)
这样的解决方法非常简单,但我想了解为什么那里有一个 '\r' 字符。
最佳答案
在某些文件系统(特别是 Windows)中,\r\n
用作换行符。您仅使用 \n
分隔符,因此 \r
保留在外。在分隔符中添加 \r
。
为了使您的代码更加健壮,请使用 System.lineSeparator()
获取换行符并相应地使用分隔符。
关于java - Java中用Scanner读取文本文件——Token的返回字符,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13649392/