请问如何将一个Unicode字符串转换为汉字。如,输入\u4e2d,输出中。
我说的并不是一般的直接赋值String str = "\u4e2d";
而是在编译之后赋值,比如说读一个txt文件,文件内容是\u4e2d,如何将这个文件中的字符串在控制台输出中文。
我查过了,好像java是在编译的时候自动将Unicode码转化的,现在怎么在运行中转化,请教
我说的并不是一般的直接赋值String str = "\u4e2d";
而是在编译之后赋值,比如说读一个txt文件,文件内容是\u4e2d,如何将这个文件中的字符串在控制台输出中文。
我查过了,好像java是在编译的时候自动将Unicode码转化的,现在怎么在运行中转化,请教
char[]c=str.toCharArray();
System.out.println(new String(c));……嘎嘎。。貌似很简单的说。。
当 String str = "Unicode码"; 的时候,编译器就已经把Unicode自动转换了,你可以输出str.length()看看,而我说的字符串,输出的是转换前的长度。
已经可以弄出来了。还是还有一点问题
public static String loadConvert (char[] in, int off, int len, char[] convtBuf)请问len,convtBuf怎么指定啊,我的是未知的Unicode。
int len=line.length();
char[] out=new char[len];//保存解析以后的结果
int outLen=0;
for(int i=0;i<len;i++){
char aChar=line.charAt(i);
if(aChar=='\\'){
aChar=line.charAt(++i);
if(aChar=='u'){
int value=0;
for(int j=0;j<4;j++){
aChar=line.charAt(++i);
switch (aChar) {
case '0': case '1': case '2': case '3': case '4':
case '5': case '6': case '7': case '8': case '9':
value = (value << 4) + aChar - '0';
break;
case 'a': case 'b': case 'c':
case 'd': case 'e': case 'f':
value = (value << 4) + 10 + aChar - 'a';
break;
case 'A': case 'B': case 'C':
case 'D': case 'E': case 'F':
value = (value << 4) + 10 + aChar - 'A';
break;
default: throw new IllegalArgumentException("Malformed \\uxxxx encoding.");
}
}
out[outLen++]=(char)value;
}else{
if (aChar == 't') aChar = '\t';
else if (aChar == 'r') aChar = '\r';
else if (aChar == 'n') aChar = '\n';
else if (aChar == 'f') aChar = '\f';
out[outLen++] = aChar;
}
}else{
out[outLen++] = aChar;
}
}
return new String (out, 0, outLen);
}
//调用的时候:
public static void main(String rags[])throws Exception{
BufferedReader br=new BufferedReader(new InputStreamReader(new FileInputStream("1.txt")));
String line="";
while((line=br.readLine())!=null){
System.out.println(parseUnicode(line));
}
br.close();}