VBnet操作文本文件的问题
来源:岁月联盟
时间:2005-01-12
但是使用的时候也不能全部都按照ASCII来读,因为你也无法保证系统上是否会读到UNICODE的文件。因此,需要一个侦测文件编码类型并且能够按照相应类型来读取的方法。
找了一个小时,终于找到了。
如果文件是有特定编码格式的,这个编码会记录在文件的头四个字节里。因此,读出这四个字节,检查是否是Unicode就可以了。如果这四个字节并没有特定的意义,你就只能猜测一个了,一般情况下,就Default就比较合适了。
Public Function LoadFile(ByVal FileName As String) As String
Dim enc As Encoding
Dim file As FileStream = New FileStream(FileName, FileMode.Open, FileAccess.Read, FileShare.Read)
If file.CanSeek Then
Dim bom(3) As Byte
file.Read(bom, 0, 4)
If ((bom(0) = &HEF And bom(1) = &HBB And bom(2) = &HBF) Or (bom(0) = &HFF And bom(1) = &HFE) Or (bom(0) = &HFE And bom(1) = &HFF) Or (bom(0) = 0 And bom(1) = 0 And bom(2) = &HFE And bom(3) = &HFF)) Then
enc = Encoding.Unicode
Else
enc = Encoding.Default
End If
file.Seek(0, SeekOrigin.Begin)
Else
enc = Encoding.Default
End If
Dim FileByte(file.Length) As Byte
file.Read(FileByte, 0, file.Length)
'转成系统对应的编码字符
Dim MyEncoder As Encoding = enc
file.Close()
file = Nothing
Return New String(MyEncoder.GetChars(FileByte))
End Function
上一篇:C#and VB.net
下一篇:XML数据分页技术的探讨











