有时候需要输出汉字的Unicode值,而且不是在property文件中,这样就没有现成的方法,其实,
System.out.println((int)'我');
输出的数字就是10进制的unicode值,转为16进制即可。
自己写的转换函数:
/**
* 返回16进制字符串
* @param k 待转换的10进制整数
* @return 16进制字符串
* @param headOrNo 是否加"0x"开头,是则加,否则不加
*/
public static String toHex(int k, boolean headOrNo) {
StringBuffer sb = new StringBuffer("");
String flag = "0x";
if (k < 0) {
flag = "-0x";
k *= -1;
}
int t;
do {
t = k % 16;
if (t > 9) {
char c = 'A';
for (int i=0; i<t-10; i++,c++);
sb.insert(0,c);
} else {
sb.insert(0,t);
}
k /= 16;
} while(k > 0);
if (headOrNo) {
sb.insert(0,flag);
} else {
return sb.toString();
}
return sb.toString();
}
/**
* 返回字符的unicode码字符串
* @param c 待转换的字符
* @return 字符的unicode码:/uXXXX
*/
public static String char2Unicode(char c) {
return "/u" + toHex(c, false);
}
/**
* 返回字符串的unicode码字符串
* @param s 待转换的字符串
* @return 字符串的unicode码:/uXXXX/uXXXX
*/
public static String getUnicode2(String s) {
StringBuffer sb = new StringBuffer("");
char c[] = s.toCharArray();
for (int i=0; i<c.length; i++) {
sb.append(char2Unicode(c[i]));
}
return sb.toString();
}
Unicode联盟的网站有一个到码表的链接,列出了16位码值。英语,法语,德语,葡萄牙语和西班牙语字符都在Basic Latin区,日语字符在Hiragana区,俄语字符在Cyrillic区,汉语字符在CJK Unified Ideographs 区。
posted on 2007-12-05 11:50
cccp21 阅读(981)
评论(0) 编辑 收藏