我有一个用西班牙语写的文件,所以它充满了像这样的字符:
á é í ó ú ñ Ñ Á É Í Ó Ú
我需要读取文件,因此我这样做:
fr = new FileReader(ficheroEntrada);
BufferedReader rEntrada = new BufferedReader(fr);
String linea = rEntrada.readLine();
if (linea == null) {
logger.error("ERROR: Empty file.");
return null;
}
String delimitador = "[;]";
String[] tokens = null;
List<String> token = new ArrayList<String>();
while ((linea = rEntrada.readLine()) != null) {
// Some parsing specific to my file.
tokens = linea.split(delimitador);
token.add(tokens[0]);
token.add(tokens[1]);
}
logger.info("List of tokens: " + token);
return token;
当我阅读令牌列表时,所有的特殊字符都消失了,并被这种字符所代替:
Ó = Ó
Ñ = Ñ
等等,发生了什么?我以前从没遇到过字符集的问题(我认为这是一个字符集问题)。是因为这台电脑吗?我该怎么办?
任何额外的建议都将不胜感激,我正在学习!谢谢!
InputStreamReader
并指定适当的编码方式。FileReader
会假设“默认”编码,因此无法正确解码字符。 - nhahtdh