若是想用python作接口測試,咱們首先有不得不瞭解和學習的模塊。它就是第三方模塊:Requests。 雖然Python內置的urllib模塊,用於訪問網絡資源。可是,它用起來比較麻煩,並且,缺乏不少實用的高級功能。更好的方案是使用html
requests。它是一個Python第三方庫,處理URL資源特別方便。查看其中文官網:cn.python-requests.org/zh_CN/lates… 英文官網:www.python-requests.org/en/master/ 能夠看一下它的不少實用的高級功能。python
Requests 徹底知足今日 web 的需求。web
.netrc
您若是安裝了Anaconda,requests就已經可用了。不然,須要在命令行下經過pip安裝:json
pip install requests複製代碼
注意:pip很容易就會版本升級,瀏覽器
方法1:檢測並更新bash
pip list –outdated複製代碼
方法2:服務器
♦先卸載:微信
pip uninstall packagename複製代碼
♦在用:easy_install.exe安裝cookie
easy_install.exe pip複製代碼
出現Installing collected packages: idna, chardet, certifi, requests網絡
Successfully installed certifi-2019.3.9 chardet-3.0.4 idna-2.8 requests-2.21.0 說明requests模塊安裝成功!
一、將安裝好的requests模塊導入後,經過GET訪問一個URL地址的網頁頁面,如:https://www/douban.com
二、這裏的 r 也就是 response,請求後的返回值,能夠調用 response 裏的 status_code 方法查看狀態碼
三、狀態碼 200 只能說明這個接口訪問的服務器地址是對的,並不能說明功能 OK,通常要查看響應的內容,r.text 是返回文本信息
看吧!這個就是requests的威力,看起來是否是很神奇很牛逼:
一、再發一個帶參數的 get 請求,如在豆瓣網搜索:西遊記,url 地址爲:https://www.douban.com/search?q=西遊記
二、請求參數:q=西遊記,能夠以字典的形式傳參:{"q": "西遊記"}
三、多個參數格式:{"key1": "value1", "key2": "value2", "key3": "value3"}
這部分最容易犯錯的部分,就是一、豆瓣網址後沒有+/search;二、params錯誤的寫成param
一、豆瓣網首頁若是用 r.text 會發現獲取到的內容有亂碼,由於豆瓣網首頁響應內容是 gzip 壓縮的(非 text 文本)
二、若是是在 fiddler 工具亂碼,是能夠點擊後解碼的,在代碼裏面能夠用 r.content 這個方法,content 會自動解碼 gzip 和 deflate 壓縮(這個就是開始介紹requests的高級功能:自動解碼和自動解壓)
1.response 的返回內容(content)還有其它更多信息
-- r.status_code #響應狀態碼
-- r.content #字節方式的響應體,會自動爲你解碼 gzip 和deflate 壓縮
-- r.headers #以字典對象存儲服務器響應頭,可是這個字典比較特殊,字典鍵不區分大小寫,若鍵不存在則返回 None
-- r.json() #Requests 中內置的 JSON 解碼器,requests的方便之處還在於,對於特定類型的響應,例如JSON,能夠直接獲取
-- r.url # 獲取 url
-- r.encoding # 編碼格式,requests自動檢測編碼
-- r.cookies # 獲取 cookie
-- r.raw #返回原始響應體-- r.text #字符串方式的響應體,會自動根據響應頭部的字符編碼進行解碼
-- r.raise_for_status() #失敗請求(非 200 響應)拋出異常
用requests發送get請求的接口,就是這麼簡單!想要學的趕快行動起來,鍵盤敲起來,你能夠用本身的博客園練習一下。
【python接口自動化交流羣】:984942724
您的確定就是我進步的動力。若是你感受還不錯,就請鼓勵一下吧!記得點波 推薦哦!!!(點擊右邊的小球便可!(^__^) 嘻嘻……)
我的公衆號
微信羣 (微信羣已滿100,能夠加宏哥的微信拉你進羣,請備註:進羣)