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,就表示读取完成了。

posted on 2012-07-02 09:24  流星落  阅读(1177)  评论(0编辑  收藏  举报

导航