求VB将UTF-8编码的TXT文件转换成ANSI编码的代码

如题。。。是将文件转换,不是字符串哦。。。... 如题。。。
是将文件转换,不是字符串哦。。。
展开
 我来答
zx001z7d53
2011-11-07 · TA获得超过2万个赞
知道大有可为答主
回答量:2.4万
采纳率:52%
帮助的人:5553万
展开全部
立一个模块,复制下面代码
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格式编码了,不会出现乱码问题
追问
这个代码之前用过了,得到的结果有问题,比如“开始”这个词转换后就变成了"开??",呃
苏小羿0315
2012-04-20 · 超过15用户采纳过TA的回答
知道答主
回答量:221
采纳率:100%
帮助的人:150万
展开全部
用编码转换工具就可以了。下载一个飞梭TXT文本数据处理百宝箱,就可以直接转换。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友bdb9803
2011-11-07 · TA获得超过1.1万个赞
知道大有可为答主
回答量:1.1万
采纳率:53%
帮助的人:1亿
展开全部
如楼上所说,楼主提问前也不百度一下
更多追问追答
追问
昨晚我的确是搜索到了这段代码,但是不知为啥运行后得到的是乱码,我就想找找有木有其他的代码。。。真是见鬼
程序将一个UTF-8的文本和一个ANSI的文本混合,转换以后就乱了。。混合以后原来ANSI的文本没问题,UTF8的文本乱掉了,唉
追答
UTF-8和ansi是两套不同的编码方式,怎么能混合呢?
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
匿名用户
2011-11-07
展开全部
这个问题已经有人答过了

参考资料: http://zhidao.baidu.com/question/123224632.html?fr=im2

已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式