在用StreamReader sr = new StreamReader(FileName); 的時候,再輸出sr.ReadLine();的時候,發現文件中的中文部分全都變成了亂碼。
原因:
******究其原因,原來自從Windows 2000之後的操作系統在文件處理時默認編碼採用Unicode,所以.Net 的文件默認編碼也是Unicode。除非另外指定,StreamReader 的默認編碼爲 Unicode,而不是當前系統的 ANSI 代碼頁。但是文檔大部分還是以ANSI編碼儲存,中文文本使用的是gb2312,所以才造成中文亂碼的狀況,也就是說在讀取文本的時候要指定編碼格式。
******
解決方法是System.Text.Encoding.Default 告訴
StreamReader 目前操作系統的編碼即可。
StreamReader reader = new StreamReader(FileName, System.Text.Encoding.Default)