午夜国产狂喷潮在线观看|国产AⅤ精品一区二区久久|中文字幕AV中文字幕|国产看片高清在线

    vbs中將GB2312轉Unicode的代碼
    來源:易賢網 閱讀:1290 次 日期:2016-07-07 14:40:32
    溫馨提示:易賢網小編為您整理了“vbs中將GB2312轉Unicode的代碼”,方便廣大網友查閱!

    現(xiàn)在都是utf-8編碼的時代了。responseText對utf-8編碼支持得很好,但是如果是gb2312編碼就會返回亂碼,有時甚至會報錯。

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

    代碼如下:

    Dim http

    Set http = CreateObject("msxml2.xmlhttp")

    http.open "GET","http://www.sina.com.cn/",False

    http.send

    WScript.Echo http.responseText

    但是卻發(fā)現(xiàn)返回的中文都是亂碼,看了一下發(fā)現(xiàn)新浪的編碼竟然是gb2312的,汗,現(xiàn)在都是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函數(shù),用ado很容易實現(xiàn):

    代碼如下:

    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的代碼

    2025國考·省考課程試聽報名

    • 報班類型
    • 姓名
    • 手機號
    • 驗證碼
    關于我們 | 聯(lián)系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
    工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
    聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關注公眾號:hfpxwx
    咨詢QQ:1093837350(9:00—18:00)版權所有:易賢網