原文地址:http://www.cnblogs.com/onlyendure/archive/2008/03/25/1121247.html
在編寫文本文件讀寫程序的過程中,有如下代碼
StreamReader sr = new StreamReader(FileName);
結(jié)果發(fā)現(xiàn)打開中文文本文件出現(xiàn)亂碼。
究其原因,原來自從Windows 2000之后的操作系統(tǒng)在文件處理時(shí)默認(rèn)編碼采用Unicode,所以.Net 的文件默認(rèn)編碼也是Unicode。除非另外指定,StreamReader 的默認(rèn)編碼為 Unicode,而不是當(dāng)前系統(tǒng)的 ANSI 代碼頁。但是文檔大部分還是以ANSI編碼儲(chǔ)存,中文文本使用的是gb2312,所以才造成中文亂碼的狀況,也就是說在讀取文本的時(shí)候要指定編碼格式。
但是問題來了,System.Text.Encoding 里面一堆編碼格式ASCII、UTF-8等等,要選哪一個(gè)好?
其實(shí)很簡(jiǎn)單,用
System.Text.Encoding.Default 告訴
StreamReader 目前操作系統(tǒng)的編碼即可。
StreamReader reader = new StreamReader(FileName, System.Text.Encoding.Default)
posted on 2010-06-12 17:39
漂漂 閱讀(700)
評(píng)論(0) 編輯 收藏 引用 所屬分類:
c#開發(fā)