最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 正文

VB 读取文本乱码问题,文本编码为UTF-8

来源:动视网 责编:小OO 时间:2025-09-24 17:00:31
文档

VB 读取文本乱码问题,文本编码为UTF-8

根据反馈,代码已作修改并调试通过:分二步:一、建立一个模块,复制下面代码OptionExplicitPrivateDeclareFunctionMultiByteToWideCharLib"kernel32"(ByValCodePageAsLong,ByValdwFlagsAsLong,ByReflpMultiByteStrAsAny,ByValcchMultiByteAsLong,ByVallpWideCharStrAsLong,ByValcchWideCharAsLong)AsLongPr
推荐度:
导读根据反馈,代码已作修改并调试通过:分二步:一、建立一个模块,复制下面代码OptionExplicitPrivateDeclareFunctionMultiByteToWideCharLib"kernel32"(ByValCodePageAsLong,ByValdwFlagsAsLong,ByReflpMultiByteStrAsAny,ByValcchMultiByteAsLong,ByVallpWideCharStrAsLong,ByValcchWideCharAsLong)AsLongPr
根据反馈,代码已作修改并调试通过:

分二步:

一、建立一个模块,复制下面代码

Option Explicit

Private Declare Function MultiByteToWideChar Lib "kernel32" (ByVal CodePage As Long, ByVal dwFlags As Long, ByRef lpMultiByteStr As Any, ByVal cchMultiByte As Long, ByVal lpWideCharStr As Long, ByVal cchWideChar As Long) As Long

Private Const CP_UTF8 = 65001

'读文件至变量

Private Function GetFile(FileName As String) As String

Dim i As Integer, BB() As Byte

    If Dir(FileName) = "" Then Exit Function

    i = FreeFile

    ReDim BB(FileLen(FileName) - 1)

    Open FileName For Binary As #i

    Get #i, , BB

    Close #i

    GetFile = BB

End Function

'功能: 把Utf8字符转化成ANSI字符

Public Function UTF8_Decode(FileName As String) As String

Dim sUTF8 As String

Dim lngUtf8Size As Long

Dim strBuffer As String

Dim lngBufferSize As Long

Dim lngResult As Long

Dim bytUtf8() As Byte

Dim n As Long

    sUTF8 = GetFile(FileName)

    If LenB(sUTF8) = 0 Then Exit Function

    On Error GoTo EndFunction

    bytUtf8 = sUTF8

    lngUtf8Size = UBound(bytUtf8) + 1

    lngBufferSize = lngUtf8Size * 2

    strBuffer = String$(lngBufferSize, vbNullChar)

    lngResult = MultiByteToWideChar(CP_UTF8, 0, bytUtf8(0), _

            lngUtf8Size, StrPtr(strBuffer), lngBufferSize)

    If lngResult Then

        UTF8_Decode = Left(strBuffer, lngResult)

    End If

EndFunction:

  

End Function

二、调用举例:

如果你想把一个"c:\\1.txt"的UTF-8文件转换为ANSI编码,可这样调用

dim s as string

s=UTF8_Decode("c:\\1.txt") '文件名请根据实际修改

此时,s存放的就是ANSI格式编码了,不会出现乱码问题

文档

VB 读取文本乱码问题,文本编码为UTF-8

根据反馈,代码已作修改并调试通过:分二步:一、建立一个模块,复制下面代码OptionExplicitPrivateDeclareFunctionMultiByteToWideCharLib"kernel32"(ByValCodePageAsLong,ByValdwFlagsAsLong,ByReflpMultiByteStrAsAny,ByValcchMultiByteAsLong,ByVallpWideCharStrAsLong,ByValcchWideCharAsLong)AsLongPr
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top