亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

vbs中如何將GB2312轉Unicode

發布時間:2021-10-08 13:53:26 來源:億速云 閱讀:154 作者:小新 欄目:開發技術

小編給大家分享一下vbs中如何將GB2312轉Unicode,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

今天寫了一個類似于下面的程序:

代碼如下:

Dim http
Set http = CreateObject("msxml2.xmlhttp")
http.open "GET","http://www.sina.com.cn/",False
http.send
WScript.Echo http.responseText


但是卻發現返回的中文都是亂碼,看了一下發現新浪的編碼竟然是gb2312的,汗,現在都是utf-8編碼的時代了。responseText對utf-8編碼支持得很好,但是如果是gb2312編碼就會返回亂碼,有時甚至會報錯。無奈,只好用responseBody然后自己轉碼。

代碼如下:


Dim http
Set http = CreateObject("msxml2.xmlhttp")
http.open "GET","http://www.sina.com.cn/",False
http.send
WScript.Echo GB2312ToUnicode(http.responseBody)


于是就要自己寫一個GB2312ToUnicode函數,用ado很容易實現:

代碼如下:


Function GB2312ToUnicode(str)
With CreateObject("adodb.stream")
.Type = 1 : .Open
.Write str : .Position = 0
.Type = 2 : .Charset = "gb2312"
GB2312ToUnicode = .ReadText : .Close
End With
End Function


這樣返回的就是VBS字符串默認的Unicode編碼了,不過用ado不能顯示我鬼使神差的VBS水平,于是自己根據“算法”再寫了一個:

復制代碼 代碼如下:


Function GB2312ToUnicode(str)
length = LenB(str) : out = ""
For i = 1 To length
c = AscB(MidB(str,i,1))
If c <= 127 Then
out = out & Chr(c)
Else
i = i + 1
d = Hex(AscB(MidB(str,i,1)))
c = "&H" & Hex(c) & d
out = out & Chr(c)
End If
Next
GB2312ToUnicode = out
End Function 

只可惜效率太低,就當練練手吧。

以上是“vbs中如何將GB2312轉Unicode”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

罗江县| 饶平县| 牙克石市| 巢湖市| 邮箱| 彩票| 安塞县| 泌阳县| 杭锦后旗| 嵩明县| 新乡市| 和顺县| 应用必备| 南丹县| 延吉市| 化德县| 龙州县| 渭源县| 孝义市| 吉安县| 金川县| 奉新县| 那坡县| 大埔县| 喜德县| 安陆市| 云阳县| 西昌市| 临武县| 黄山市| 岳西县| 麻阳| 布拖县| 河南省| 武强县| 多伦县| 永德县| 安化县| 宜黄县| 同德县| 额尔古纳市|