我正在编写一个翻译程序,它从文本文件中读取翻译。此方法从文本文件中读取并将其添加到我用于字典的Map对象中。
public Map<String, String> loadTranslations() throws IOException {
Map<String, String> translations = new HashMap<String, String>();
BufferedReader in = null;
try {
in = new BufferedReader(new FileReader(System.getProperty("user.dir") + "\\resource\\translations.txt"));
englWord = in.readLine();
frenWord = in.readLine();
translations.put(englWord, frenWord);
System.out.println(englWord + "\n" + frenWord + "\n" + translations);
} catch(Exception e) {
JOptionPane.showMessageDialog(this, "An Error Occured!", "Error!", JOptionPane.ERROR_MESSAGE);
e.printStackTrace();
} finally {
in.close();
}
JOptionPane.showMessageDialog(this, "Updated!", "", JOptionPane.INFORMATION_MESSAGE);
return translations;
}
但每当我运行它时,它不打印文本文件中的单词而是打印出来;
潮攍ੵ渍ੴ睯ഊ摥畸ഊ瑨牥攍ੴ牯楳ഊ景畲ഊ煵慴牥ഊ晩癥ഊ捩湱ഊ獩砍ੳ楸ഊ獥癥渍ੳ数琍楧桴ഊ桵楴ഊ湩湥ഊ湥畦ഊ瑥渍楸
null
{潮攍ੵ渍ੴ睯ഊ摥畸ഊ瑨牥攍ੴ牯楳ഊ景畲ഊ煵慴牥ഊ晩癥ഊ捩湱ഊ獩砍ੳ楸ഊ獥癥渍ੳ数琍楧桴ഊ桵楴ഊ湩湥ഊ湥畦ഊ瑥渍楸=null}
文本文件只列出了英文和法文的前十个字母,所以输出应该是类似的;
one
un
{one=un}
我该如何解决这个问题?
答案 0 :(得分:3)
如果您未指定编码,则会获得depends on how the JVM gets initialized的默认值。您可以指定如下的显式编码:
FileInputStream fis = new FileInputStream("test.txt");
InputStreamReader isr = new InputStreamReader(fis, "UTF8");
BufferedReader in = new BufferedReader(isr);
此代码读取文件,假定内容以UTF8编码。