C#使用StreamReader类读取汉字

我们上个例子中的代码:

using System;

using System.Collections.Generic;

using System.Text;

using System.IO;

class Program

{

static void Main(string[]args)

{

try

{

FileStream aFile = new FileStream(@"c:\祝福.txt", FileMode.Open);

StreamReader sr = new StreamReader(aFile);

string strLine = sr.ReadLine();

while(strLine != null)

{

Console.WriteLine(strLine);

strLine = sr.ReadLine();

}

sr.Close();

}

catch (IOException ex)

{

Console.WriteLine(ex.Message);

Console.ReadLine();

return ;

}

Console.ReadKey();

}

}

如果在文件中出现汉字,那么读出来就是乱码。为了解决这个问题,我们用如下代码:

using System;

using System.Collections.Generic;

using System.Text;

using System.IO;

class Program

{

static void Main(string[]args)

{

try

{

string strLine;

FileStream aFile = new FileStream(@"c:\祝福.txt", FileMode.Open);

StreamReader sr = new StreamReader(aFile,System.Text.Encoding.GetEncoding("gb2312"));

//如果有汉字,必需要加入第二个编码参数,要不读出来就是乱码,如果全是英文,可以不加这个参数。

while ((strLine = sr.ReadLine())!= null)

{

Console.WriteLine(strLine);

strLine = sr.ReadLine();

}

sr.Close();

}

catch (IOException ex)

{

Console.WriteLine(ex.Message);

Console.ReadLine();

return ;

}

Console.ReadKey();

}

}

对以上代码我作出以下解释:

StreamReader sr= new StreamReader(aFile, System.Text.Encoding.GetEncoding("gb2312"));

//如果有汉字,必需要填入第二个编码参数,要不读出来就是乱码,如果全是英文,可以不要这个参数。

(strLine = sr.ReadLine())!=null

上式可以分解为如下:

1: strLine=sr.ReadLine();

//sr.ReadLine()就是按行读数据,行之间用“\n”分割;strLine=sr.ReadLine(); 是一个赋值表达式,这个表达式也有一个结果,就是strLine的值。

2: if(strLine!=null) 则条件成立,当ReadLine读到null的时候给了strLine,这时strLine为null,就表示读取完成了。