我有一些像这样编码的汉字:
String b = "\\u91d1\\u5143\\u6bd4\\u8054\\u6210\\u957f\\u52a8\\u529b";
怎样才能把字符串b改成真正的字符,我发现在控制台输出的时候可以显示下面的c,那么问题是如何把字符串b改成c呢?
String c = "\u91d1\u5143\u6bd4\u8054\u6210\u957f\u52a8\u529b";
我有一些像这样编码的汉字:
String b = "\\u91d1\\u5143\\u6bd4\\u8054\\u6210\\u957f\\u52a8\\u529b";
怎样才能把字符串b改成真正的字符,我发现在控制台输出的时候可以显示下面的c,那么问题是如何把字符串b改成c呢?
String c = "\u91d1\u5143\u6bd4\u8054\u6210\u957f\u52a8\u529b";
如果字符串中实际上包含双斜杠,那么您将不得不手动扫描字符串,解码并用实际的 UTF-16 表示替换每个“\uXXXX”序列。例如(未经测试):
StringBuilder buf = new StringBuilder();
char c[2];
for (int i = 0; i < b.length(); i += 7)
{
int tmp = Integer.parseInt(b.substring(i+3, i+7), 16);
if (tmp < 0x1000)
{
c[0] = (char) tmp;
c[1] = 0;
}
else
{
tmp -= 0x10000;
c[0] = (0xD800 | ((tmp & 0xFFC00) >> 10));
c[1] = (0xDC00 | (tmp & 0x3FF));
}
buf.append(c, 2);
}
b = buf.ToString();
有人发布了一个棘手的解决方案,但对我来说似乎很好:
b="abc="+b;
Properties props = new Properties();
props.load(new StringReader(b));
b=props.getProperty("abc");
System.out.println(b);