通过C#读取txt文件(在unicode和utf8中)

前端之家收集整理的这篇文章主要介绍了通过C#读取txt文件(在unicode和utf8中)前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我创建了两个txt文件( Windows记事本)与相同的内容“谢谢 – спасибо”,并保存在utf8和unicode.在记事本他们看起来很好.然后我试图用.Net读取它们:
...File.ReadAllText(utf8FileFullName,Encoding.UTF8);

...File.ReadAllText(unicodeFileFullName,Encoding.Unicode);

但是在这两种情况下,我都得到了这个“谢谢你 – ”.怎么了?

UPD:
utf8的代码

static void Main(string[] args)
        {
            var encoding = Encoding.UTF8;
            var file = new FileInfo(@"D:\encodes\enc.txt");
            Console.OutputEncoding = encoding;
            var content = File.ReadAllText(file.FullName,encoding);
            Console.WriteLine("encoding: " + encoding);
            Console.WriteLine("content: " + content);
            Console.ReadLine();
        }

结果:
谢谢ÑпаÑибо

解决方法

编辑为UTF8应该支持字符.看来你输出到一个控制台或一个没有编码的位置.如果是这样,你需要设置编码.对于控制台,您可以做到这一点
string allText = File.ReadAllText(unicodeFileFullName,Encoding.UTF8);
Console.OutputEncoding = Encoding.UTF8;
Console.WriteLine(allText);
原文链接:https://www.f2er.com/csharp/95554.html

猜你在找的C#相关文章