request对数据的操作
响应数据
响应内容
获取响应数据内容:
-
res.text 获取HTML文本
-
res.content 获取二进制流
-
res.json() 获取json数据
-
res.encoding 获取响应的格式
-
res.encoding = ‘utf-8’ 更改获取到的格式
其中Text是以文本的格式打开内容,常用来查看html网页
Content是以二进制的格式打开内容,常用来查看非文本的内容,如视频,图片,声音等
>>> r = requests.get('https://api.github.com/events')
>>> r.text
u'[{"repository":{"open_issues":0,"url":"https://github.com/...
你可以找出 Requests 使用了什么编码,并且能够使用r.encoding 属性来改变它:
如果requests获取的网页格式导致网页中中文乱码,可以使用r.encoding来更改获取到内容的格式。
>>> r.encoding
'utf-8'
>>> r.encoding = 'ISO-8859-1'
获取响应数据的属性:
-
res_code = res.status_code # 响应状态码(*)
-
res_headers = res.headers # 响应头信息
-
res_url = res.url # 此响应对应的请求url
-
res_cookie = res.cookies # 响应的cookies(*)
-
res_history = res.history # 请求历史
json形式与流形式的响应数据示例
网站与浏览器之间交互数据除了视频,图片。网页,还会有一些数据上的交流,这些数据使用的就是json格式,所有requests提供了专门解析json格式的方法
json就是一个字符串,体积小,使网站与服务器之间方便交流,相当于网站与服务器之间的书信。
字符串无法被python所使用,所有使用.json方法,将json格式的字符串转变成python所能理解的元组或者列表。
json形式响应数据示例: bilibili的Python视频教程, 目录列表
import requests
headers = {
'User-Agent':'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/75.0.3770.142 Safari/537.36'
}
url='https://api.bilibili.com/x/web-interface/view?aid=14184325&cid=23153678'
res = requests.get(url=url, headers=headers)
print(res)
print(res.status_code)
print(res.headers)
print('-----------------------------------------------------------------------------')
print(res.json())