如何用EXCEL VBA将汉字转成GB2312的URL编码,如输入"中国",生成"%D6%D0%B9%FA",用于网络查询.

 我来答
巴哥泡泡
2010-09-25 · TA获得超过1040个赞
知道大有可为答主
回答量:1040
采纳率:0%
帮助的人:1151万
展开全部
据说有 MultiByteToWideChar 和 WideCharToMultiByte 这两个函数可以使用,但是我没用过!
写了2个函数,自己改吧!
Public Function uncode(x As Range) As String
On Error Resume Next
MsgBox Asc(Mid(x, 1, 1)) + 65536
If x.Columns.Count <> 1 Then
uncode = "Error"
Exit Function
End If
If Len(x) = 0 Then Exit Function
Dim a, b, c, i
b = ""
For i = 1 To Len(x)
a = Mid(x, i, 1)
If Asc(a) < 0 Then
uncode = uncode & sixteen(Asc(a) + 65536)
Else
uncode = uncode & a
End If
Next
End Function
Public Function sixteen(m As Long) As String
n = m
x = "": y = ""
Do While n <> 0
a = n Mod 2
n = n \ 2
x = a & x
Loop

Do While Len(x) Mod 4 <> 0
x = "0" + x
Loop
Do While Len(x) > 0
Select Case Right(x, 4)
Case "0000"
y = "0" + y
Case "0001"
y = "1" + y
Case "0010"
y = "2" + y
Case "0011"
y = "3" + y
Case "0100"
y = "4" + y
Case "0101"
y = "5" + y
Case "0110"
y = "6" + y
Case "0111"
y = "7" + y
Case "1000"
y = "8" + y
Case "1001"
y = "9" + y
Case "1010"
y = "A" + y
Case "1011"
y = "B" + y
Case "1100"
y = "C" + y
Case "1101"
y = "D" + y
Case "1110"
y = "E" + y
Case "1111"
y = "F" + y
End Select
x = Left(x, Len(x) - 4)
Loop
sixteen = y
End Function
来自:求助得到的回答
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
jianzhao84
2010-09-25 · TA获得超过380个赞
知道小有建树答主
回答量:280
采纳率:0%
帮助的人:342万
展开全部
我在C#程序中会转,EXCEL中你可以用函数,VBA中不知道用什么,你用CODE(‘中’)把中字转成数字码54992,然后再用DEC2HEX(54992,4)转成十六进制数D6D0,VBA的方法我再看看。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式