如何在VB 中读取 UTF-8 格式的文件?

这个问题因扰了我很久,先在VB6 中测试多种方法,但都没有成功,最后先使用VB.Net 产生一个转换用的dll ,然后再在VB6 中调用此DLL,  以前是这样解决的。可以,有时也有问题,也是很笨的方法。

最终找到一个很简单的方法,如下,使用adodb.stream  可很方便的解决。

(其中参数为UTF-8格式文件的路径和文件名;返回一个字符串)

Public Function ReadUTF8(ByVal sUTF8File As String) As String
     If Len(sUTF8File) = 0 Or Dir(sUTF8File) = vbNullString Then Exit Function
     Dim ados As Object
     Set ados = CreateObject("adodb.stream")
     With ados
         .Charset = "utf-8"
         .Type = 2
         .Open
         .LoadFromFile sUTF8File
         ReadUTF8 = .ReadText
         .Close
     End With
     Set ados = Nothing
End Function

2008-06-03  增加直接文件对文件的转换,代码如下: (其中的两个参数均为文件路径及名件名)

Public Function UTF8_ANSI(ByVal sUTF8File As String, ByVal sANSIFile As String) As Boolean
    On Error GoTo errHandler
    UTF8_ANSI = False
   
    If Len(sUTF8File) = 0 Or Dir(sUTF8File) = vbNullString Then Exit Function
   
    Dim ados As Object
    Set ados = CreateObject("adodb.stream")
   
    Dim fso As Object
    Dim txtFile As Object
    Set fso = CreateObject("Scripting.FileSystemObject")
    Set txtFile = fso.CreateTextFile(sANSIFile, True)
   
    With ados
       .Charset = "utf-8"
       .Type = 2
       .Open
       .LoadFromFile sUTF8File
       
       txtFile.Write (.ReadText)
       txtFile.Close
   
       .Close
    End With
    Set ados = Nothing
   
    UTF8_ANSI = True
errHandler:
    If Err.Number <> 0 Then
        MsgBox Err.Description, vbOKOnly + vbInformation, "UTF8_ANSI"
    End If
End Function

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值