主頁(yè) > 知識(shí)庫(kù) > vbs 解析json jsonp的方法

vbs 解析json jsonp的方法

熱門標(biāo)簽:神行者美術(shù)館地圖標(biāo)注 佛山真人電銷機(jī)器人廠家 如何用機(jī)器人進(jìn)行電銷 東營(yíng)快遞外呼系統(tǒng) 地圖標(biāo)注政府哪個(gè)部門管 除了地圖標(biāo)注還有這種生意嗎 齊齊哈爾高德地圖標(biāo)注店 哪里有便宜的地圖標(biāo)注公司 百度地圖標(biāo)注點(diǎn)距離代碼

我收集了三種常見(jiàn) json jsonp 的格式,因?yàn)楹芏嗳苏椅艺f(shuō)如何用正則提取某個(gè)字符串,我看了下,要么是json,要么是jsonp,
正則簡(jiǎn)直浪費(fèi),比如那種空間里說(shuō)說(shuō)的數(shù)據(jù),上百條的信息,你正則個(gè)P,而且還有回復(fù)里的格式也差不多的,所以最好的方法還是解析。

先來(lái)看看常見(jiàn)的三種吧:

酷我音樂(lè)用戶信息 json 格式
http://kzone.kuwo.cn/mlog/UserVal?uid=1237357from=profile
{"work":4,"fans":275,"lp":"{\"id\":1237357,\"username\":\"亂碼\",\"pic\":\"http://img3.kuwo.cn/star/userhead/57/55/1315554310390_1237357m.jpg\"}","art":4,"album":1,"fortune":342402,"article":0,"workVideo":1,"care":195,"workAudio":3,"view":1312997,"playlist":0,"listen":278962,"collect":1}

拍拍手機(jī)查詢接口 jsonp 格式
http://virtual.paipai.com/extinfo/GetMobileProductInfo?mobile=13012345678amount=10000callname=cb
cb({mobile:'13012345678',province:'重慶',isp:'中國(guó)聯(lián)通',stock:'1',amount:'10000',maxprice:'0',minprice:'0'});

搜狐IP信息 js 格式
http://pv.sohu.com/cityjson
var returnCitySN = {"cip": "218.72.14.14", "cid": "330100", "cname": "浙江省杭州市"};

這幾種合適都可以通過(guò) htmlfile 來(lái)解析,但是方法稍微有點(diǎn)差異。

先來(lái)解析第一種 json 格式的吧。

Set html = CreateObject("htmlfile")
Set http = CreateObject("Msxml2.ServerXMLHTTP")

http.open "GET", "http://kzone.kuwo.cn/mlog/UserVal?uid=1237357from=profile", False
http.send
strHtml = http.responseText ' 得到數(shù)據(jù)

Set window = html.parentWindow
window.execScript "var json = "  strHtml, "JScript" ' 解析 json

Set kuwo = window.json ' 獲取解析后的對(duì)象
WScript.Echo "訪問(wèn)量:", kuwo.view, " 財(cái)富:", kuwo.fortune

可以得到如下信息。

再來(lái)看看 jsonp 的解析,jsonp其實(shí)只是多了一個(gè)回調(diào)函數(shù)而已,所以我們自定義一個(gè)函數(shù)解析他就可以了。

Set html = CreateObject("htmlfile")
Set http = CreateObject("Msxml2.ServerXMLHTTP")
callback = "cb"
url = "http://virtual.paipai.com/extinfo/GetMobileProductInfo?mobile=13012345678amount=10000callname="  callback

http.open "GET", url, False
http.send
strHtml = http.responseText ' 得到數(shù)據(jù)
' cb({mobile:'13012345678',province:'重慶',isp:'中國(guó)聯(lián)通',stock:'1',amount:'10000',maxprice:'0',minprice:'0'});
' !--[if !IE]>|xGv00|8030d7c308afc4a32846a715ff79e9a3![endif]-->
' 得到的是這樣的數(shù)據(jù),所以要處理下
strHtml = Split(strHtml, vbLf)(0) ' 取第一行
Set window = html.parentWindow
window.execScript "function "  callback  "(o){json=o}", "JScript" ' jsonp 回調(diào)函數(shù)、
window.execScript strHtml, "JScript" ' 解析 json

Set json = window.json ' 獲取解析后的對(duì)象
WScript.Echo json.mobile, json.isp, json.province 

可以得到如下信息。

最后看下 js 格式解析,這個(gè)是最簡(jiǎn)單的,什么都不用做,但是你要知道他的變量名。

Set html = CreateObject("htmlfile")
Set http = CreateObject("Msxml2.ServerXMLHTTP")

http.open "GET", "http://pv.sohu.com/cityjson", False
http.send
strHtml = http.responseText ' 得到數(shù)據(jù)
' 得到 var returnCitySN = {"cip": "218.72.14.14", "cid": "330100", "cname": "浙江省杭州市"};

Set window = html.parentWindow
window.execScript strHtml, "JScript" ' 解析 js

Set js = window.returnCitySN ' 獲取解析后的對(duì)象
WScript.Echo js.cname, js.cip, js.cid 

可以得到如下信息

js 格式的是最簡(jiǎn)單的,但要注意,變量名是他定的,所以你在 獲取解析后的對(duì)象 那一步,要寫上他的變量名。
json 格式,我們只要給他加上變量名然后解析即可。
jsonp 相對(duì)麻煩點(diǎn),因?yàn)橐獙懸粋€(gè)自定義回調(diào)函數(shù)。

總的來(lái)說(shuō),方法差不多,只是解析部分稍微有點(diǎn)不同而已。
用 htmlfile 解析,是不是比 正則 方便?

以后玩 POST 別再用落伍的 instr+mid 或者 正則 去解析 html json了, htmlfile 才是王道。

標(biāo)簽:銅川 鶴壁 四平 西安 湖州 邢臺(tái) 文山 ???/a>

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《vbs 解析json jsonp的方法》,本文關(guān)鍵詞  vbs,解析,json,jsonp,的,方法,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《vbs 解析json jsonp的方法》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于vbs 解析json jsonp的方法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章