C#读取文本文件乱码的解决

C#读取文本文件最简单的方法就是使用StreamReader类,下面的例子来自Visual Studio的帮助:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.IO;

namespace Test
{
class Program
{
static void Main(string[] args)
{
  StreamReader sr = new StreamReader(@”d:\1.txt”);
  string line;
  while ((line = sr.ReadLine()) != null)
  {
    Console.WriteLine(line);
  }
  sr.Close();
}
}
}

运行这个例子后,你会发现输出的中文是乱码的,其实,帮助里面已经有说明了,默认是UTF-8编码,如果把上面的D:\1.txt改成UTF-8的 编码,输出的文字就正确了。那么,如果要读取ANSI编码的文件怎么办呢?其实很简单,可以在实例化StreamReader时,指定编码:

StreamReader sr = new StreamReader(@”d:\1.txt”, System.Text.ASCIIEncoding.Default);

把上面的例子这样一改,结果就不再是乱码了。

文章转载自:http://www.ebusoft.cn/blog/archives/57.html

原文地址:https://www.cnblogs.com/zhangmo/p/2569429.html