我正在尝试在一个简单的 Java 程序中使用java.util.Scanner读取下面的文本文件。
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' 字符。