StringBuffer contents=new StringBuffer();
BufferedReader input = new BufferedReader(new FileReader("/home/xyz/abc.txt"));
String line = null; //not declared within while loop
while (( line = input.readLine()) != null){
contents.append(line);
}
System.out.println(contents.toString());
档案abc.txt
包含
\u0905\u092d\u0940 \u0938\u092e\u092f \u0939\u0948 \u091c\u0928\u0924\u093e \u091c\u094b \u091a\u093e\u0939\u0924\u0940 \u0939\u0948 \u092
我想在使用Java的控制台中用印地语显示它。
如果我只是这样打印 String str =“\ u0905 \ u092d \ u0940 \ u092e \ u092f \ u0939 \ u099 \ u091c \ u0928 \ u0924 \ u093e \ u091c \ u094b \ u091a \ u093e \ u0939 \ u0924 \ u0940 \ u0939 \ u0948 \ u092”;
的System.out.println(STR);
然后它工作正常,但当我尝试从文件中读取它不起作用。
帮助我。
答案 0 :(得分:6)
import org.apache.commons.lang3.StringEscapeUtils;
// open the file as ASCII, read it into a string, then
String escapedStr; // = "\u0905\u092d\u0940 \u0938\u092e\u092f \u0939\u0948 ..."
// (to include such a string in a Java program you would have to double each \)
String hindiStr = StringEscapeUtils.unescapeJava( escapedStr );
System.out.println(hindiStr);
(确保您的控制台设置为显示印地语(正确的字体等),控制台的编码与您的Java编码相匹配。上面的Java代码只是简单的。)
答案 1 :(得分:5)
您应将内容作为UTF-8
编码的印地语字符存储在文件中。例如,在您的情况下,它将是अभी समय है जनता जो चाहती है
。也就是说,不是保存unicode转义,而是直接保存原始的印地语字符。然后,您可以像平常一样阅读。
您只需确保您使用的编辑器使用UTF-8编码保存它。见Spanish language chars are not displayed properly?
否则,您必须将文件设为.properties
文件并使用java.util.Properties
进行阅读,因为它本身就提供了unicode unescaping支持。