回覆列表
-
1 # 使用者1811458706817
-
2 # 已經過期了
1、檔案編碼格式一般指檔案內文字字符采用什麼樣的字符集, 通常簡體中文windows採用GB2312,極個別文字字符采用utf-8字符集, 2、有時檔案編碼格式也通常指代檔案的型別,windows對程式或資料檔案的識別,一般透過副檔名來完成,也就是透過.
1、檔案編碼格式一般指檔案內文字字符采用什麼樣的字符集, 通常簡體中文windows採用GB2312,極個別文字字符采用utf-8字符集, 2、有時檔案編碼格式也通常指代檔案的型別,windows對程式或資料檔案的識別,一般透過副檔名來完成,也就是透過.
檔案的字符集在Windows下有兩種,一種是ANSI,一種Unicode。對於Unicode,Windows支援了它的三種編碼方式,一種是小尾編碼(Unicode),一種是大尾編碼(BigEndianUnicode),一種是UTF-8編碼。我們可以從檔案的頭部來區分一個檔案是屬於哪種編碼。當頭部開始的兩個位元組為 FF FE時,是Unicode的小尾編碼;當頭部的兩個位元組為FEFF時,是Unicode的大尾編碼;當頭部兩個位元組為EF BB時,是Unicode的UTF-8編碼;當它不為這些時,則是ANSI編碼。按照如上所說,我們可以透過讀取檔案頭的兩個位元組來判斷檔案的編碼格式,程式碼如下(C#程式碼):程式中System.Text.Encoding.Default是指作業系統的當前 ANSI 內碼表的編碼。
1: public System.Text.Encoding GetFileEncodeType(string filename)
2: {
3: System.IO.FileStream fs = new System.IO.FileStream(filename, System.IO.FileMode.Open, System.IO.FileAccess.Read);
4: System.IO.BinaryReader br = new System.IO.BinaryReader(fs);
5: Byte[] buffer = br.ReadBytes(2);
6: if(buffer[0]>=0xEF)
7: {
8: if(buffer[0]==0xEF && buffer[1]==0xBB)
9: {
10: return System.Text.Encoding.UTF8;
11: }
12: else if(buffer[0]==0xFE && buffer[1]==0xFF)
13: {
14: return System.Text.Encoding.BigEndianUnicode;
15: }
16: else if(buffer[0]==0xFF && buffer[1]==0xFE)
17: {
18: return System.Text.Encoding.Unicode;
19: }
20: else21: { 22: return System.Text.Encoding.Default; 23: } 24: } 25: else26: { 27: return System.Text.Encoding.Default; 28: } 29: }