我正在尝试获取此字符串表示的正确 unicode 字符:
string originalString = "\u0605\u04c3\u5000\u0000\u5000\ufd00\u4400\ud500\u7600\ud300\u4f00\ubc00\u0c00\u2d00\u4000\ue400\u0e00\u7400\u4800\ub700\u1d00\u1300\ue900\u6000\u4c00\ufb00\u9900\u3900\ud900\u6700\uae00\ueb00\u8f00\u2800\u0200\ub300\u5c00\ufe00\u0100\u3d00\u9100\u3000\u0300\u1600\u0100\u7000\u6200\u8e00\u1d00\u8e00\u6200\ua900\u6300\uc800\u0900\ub700\ub000\u6000\ue400\u9200\u3f00\u9100\u8d00\uef00\u3600\u0100\u9e00\u0081";
如果我在 cs 文件中对其进行硬编码,我可以在调试模式下看到它显示正确的字符,但是如果我在文件中写入了确切的字符串并且我尝试读取它,它会显示字符串原样文件。
TextReader tr = new StreamReader("c:\\test.txt");
string tmpString = tr.ReadLine();
tr.Close();
byte[] array = Encoding.Unicode.GetBytes(tmpString );
string finalResult = Encoding.Unicode.GetString(array);
如何使 finalResult 字符串具有正确的 unicode 字符?
在此先感谢贡萨洛
编辑:已经尝试放置
TextReader tr = new StreamReader("c:\\test.txt",Encoding.Unicode);
但字符与正确字符不同。