中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

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

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

五家渠市| 呼图壁县| 增城市| 西林县| 泾阳县| 赤城县| 车致| 呼图壁县| 徐闻县| 肥西县| 彰化市| 鄯善县| 陆良县| 宁阳县| 巍山| 江油市| 嘉善县| 贵阳市| 政和县| 吉隆县| 修水县| 资兴市| 皮山县| 徐水县| 聊城市| 衡山县| 南郑县| 栾城县| 土默特右旗| 绥宁县| 桐庐县| 平潭县| 凤台县| 桓台县| 双鸭山市| 汶上县| 丹东市| 新巴尔虎左旗| 克山县| 山阴县| 曲靖市|