C#汉字转为Unicode编码
主要⽤于⽣成json格式时,将汉字转成Unicoude编码,防⽌页⾯乱码。
  protected string GetUnicode(string text)
{
string result = "";
for (int i = 0; i < text.Length; i++)
{
if ((int)text[i] > 32 && (int)text[i] < 127)
{
result += text[i].ToString();
}
数字转unicode编码else
result += string.Format("\\u{0:x4}", (int)text[i]);
}
return result;
}
运⾏结果:
涉及的知识点:
1、“x”则代表⼗六进制,“x4”代表⼗六进制表⽰的可控制长度,如果长度不够,则⽤前导的0填补。
2、Unicode写法:在表⽰⼀个Unicode的字符时,通常会⽤“U+”然后紧接着⼀组⼗六进制的数字来表⽰这⼀个字符。
3、 ASCII 码(American Standard Code for Information Interchange,全称美国信息交换标准码)
基本的 ASCII 共有 128 个字符,其中有 96 个可打印字符,包括常⽤的字母、数字、标点符号等,另外还有 32 个。
0~31及127(共33个)是控制字符或通信专⽤字符(其余为可显⽰字符),如控制符:LF(换⾏)、CR(回车)、FF(换页)、DEL(删除)、BS(退格)、BEL(振铃)等;通信专⽤字符:SOH(⽂头)、EOT(⽂尾)、ACK(确认)等;ASCII值为8、9、10和13分别转换为退格、制表、换⾏和回车字符。它们并没有特定的图形显⽰,但会依不同的应⽤程序⽽对⽂本显⽰有不同的影响。
32~126(共95个)是字符(32sp是空格),其中48~57为0到9⼗个阿拉伯数字,65~90为26个⼤写英⽂字母,97~122为26个⼩写字母,其余为⼀些标点符号、运算符号等。
参考资料:
1、C# String.Format⽤法和格式说明