新聞中心
這篇文章主要介紹了python接口自動化之如何處理Json數(shù)據(jù),具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
json 模塊簡介
1、Json 簡介:Json,全名 JavaScript Object Notation,JSON(JavaScript Object Notation(記號、標(biāo)記))是一種輕量級的數(shù)據(jù)交換格式。它基于JavaScript(Standard ECMA-262 3rd Edition - December 1999)的一個子集。JSON采用完全獨立
于語言的文本格式,但是也使用了類似于C語言家族的習(xí)慣(包括C, C++, C#, Java, JavaScript, Perl, Python等)。這些特性使JSON成為理想的數(shù)據(jù)交換語言。JSON易于人閱讀和編寫,同時也易于機器解析和生成。常用于 http 請求中,接口
返回的數(shù)據(jù)中。
2、可以用 help(json),查看對應(yīng)的源碼注釋內(nèi)容
編碼Encode(python->json)
1、為什么要 encode,筆者在開頭就給各位小伙伴開門見山的說出來了,讓各位帶著問題來探索、來學(xué)習(xí)、來思考
2、舉個簡單例子,下圖的實例中 dict 類型經(jīng)過 json.dumps()后變成 str,True 變成了 true,False變成了 fasle
3、從json模塊的對應(yīng)源碼中可以查看到,python 數(shù)據(jù)轉(zhuǎn)化成 json可識別的數(shù)據(jù),對應(yīng)的表關(guān)系如下
解碼 decode(json->python)
1、以博客園的登錄成功結(jié)果:{"success":True}為例,我們其實最想知道的是 success 這個字段返回的是 True 還是 False,以便于我們對接口進行斷言,以下是fiddler抓包博客園登錄成功的結(jié)果
2、如果以 content 字節(jié)輸出,返回的是一個字符串:{"success":true},這樣獲取后面那個結(jié)果就不方便了,導(dǎo)致斷言也不方便
3、如果經(jīng)過 json 解碼后,返回的就是一個字典:{u'success': True},這樣獲取后面那個結(jié)果,就用字典的方式去取值:result2["success"],這樣不言而喻斷言也就簡單方便了
4、由于博客園的登錄機制的改變,我們這里接著上一篇的刪除隨筆的返回結(jié)果,給小伙伴們實戰(zhàn)演練一下
5、用fiddler抓包,抓到刪除新建隨筆的請求,從抓包結(jié)果可以看出,返回結(jié)果是一個字符串:{"isSuccess":True},按照上邊的步驟用代碼實現(xiàn)
6、代碼及結(jié)果(看到了吧,就是這么輕松被我們?nèi)〉狡鋠alue了,接下來就可以進行斷言了)
7、從json模塊的對應(yīng)源碼中可以查看到, json 數(shù)據(jù)轉(zhuǎn)化成 python 可識別的數(shù)據(jù),對應(yīng)的表關(guān)系如下
8、參考代碼
# coding:utf-8 import requests # 先打開登錄首頁,獲取部分cookie url = "https://passport.cnblogs.com/user/signin" headers = { "User-Agent": "Mozilla/5.0 (Windows NT 10.0; WOW64; rv:44.0) Gecko/20100101 Firefox/44.0" } # get方法其它加個ser-Agent就可以了 s = requests.session() r = s.get(url, headers=headers,verify=False) print (s.cookies) # 添加登錄需要的兩個cookie c = requests.cookies.RequestsCookieJar() c.set('.CNBlogsCookie', 'XXX') # 填上面抓包內(nèi)容 c.set('.Cnblogs.AspNetCore.Cookies','XXX') # 填上面抓包內(nèi)容 c.set('AlwaysCreateItemsAsActive',"True") c.set('AdminCookieAlwaysExpandAdvanced',"True") s.cookies.update(c) print (s.cookies) result = r.content print(result.decode('utf-8')) # 登錄成功后保存編輯內(nèi)容 url2= "https://i.cnblogs.com/EditPosts.aspx?opt=1" body = {"__VIEWSTATE": "", "__VIEWSTATEGENERATOR":"FE27D343", "Editor$Edit$txbTitle":"這是繞過登錄的標(biāo)題:北京-宏哥", "Editor$Edit$EditorBody":"這里是中文內(nèi)容:http://www.cnblogs.com/duhong/
", "Editor$Edit$Advanced$ckbPublished":"on", "Editor$Edit$Advanced$chkDisplayHomePage":"on", "Editor$Edit$Advanced$chkComments":"on", "Editor$Edit$Advanced$chkMainSyndication":"on", "Editor$Edit$lkbDraft":"存為草稿", } r2 = s.post(url2, data=body, verify=False) print (r.content.decode('utf-8')) # 第三步:正則提取需要的參數(shù)值 import re postid = re.findall(r"postid=(.+?)&", r2.url) print(type(postid)) print (postid) # 這里是 list # 提取為字符串 print (postid[0]) # 第四步:刪除草稿箱 url3 = "https://i.cnblogs.com/post/delete" json3 = {"postId": postid[0]} r3 = s.post(url3, json=json3, verify=False) result = r3.content #content數(shù)據(jù)是字節(jié)輸出 print(type(result)) print(result) #json是經(jīng)過加碼encode成對應(yīng)python的數(shù)據(jù)類型 result1 = r3.json() print (type(result1)) print(result1['isSuccess'])
感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“python接口自動化之如何處理Json數(shù)據(jù)”這篇文章對大家有幫助,同時也希望大家多多支持創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計公司,關(guān)注創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計公司行業(yè)資訊頻道,更多相關(guān)知識等著你來學(xué)習(xí)!
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、網(wǎng)站設(shè)計器、香港服務(wù)器、美國服務(wù)器、虛擬主機、免備案服務(wù)器”等云主機租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。
新聞名稱:python接口自動化之如何處理Json數(shù)據(jù)-創(chuàng)新互聯(lián)
URL地址:http://fisionsoft.com.cn/article/djopji.html