【Python】【有趣的模块】【requests】【二】快速上手
【一】参数及结果
【二】响应内容
>>> r = requests.get('https://github.com/timeline.json')
>>> print(r.content)
b'{"message":"Hello ......"}'
>>> print(r.encoding)
utf-8
>>> print(r.text)
{"message":"Hello....."}
【备注】如果改变了编码,每当方位r.text,Request都将会使用r.encoding的新值。你可能希望在使用特殊逻辑计算出文本的编码的情况下来修改编码。比如HTTP和XML自身可以指定编码。这样的话,应使用r.content来找到编码,然后设置r.encoding为响应的编码。
在需要的情况下,Requests也可以使用定制的编码。如果你创建了自己的编码,并使用codecs模块进行注册,就可以轻松使用这个解码器名称作为r.encoding的值,然后由Requests来为你处理编码。
【三】JSON响应内容
Requests中也有个内置的JSON解码器,助你处理JSON数据
>>> r = requests.get('https://github.com/timeline.json')
>>> r.json()
{'message':'Hello......'}
【备注】成功调用r.json()并不意味着响应的成功。有的服务器会在失败的响应中包含一个json对象。所以,要检查请求是否成功,用r.status_code来检查
>>> print(r.status_code)
410
【备注】被请求的资源在服务器上已经不可用,而且无任何的转发地址
【四】原始响应内容
>>> r = requests.get('https://gitbub.com/timeline.json',stream=True)
>>> r.raw
<urllib3.response.HTTPResponse object at 0x0000000003590BA8>
>>> r.raw.read(10)
b''
【备注】这是我自己运行的结果,官方的结果为
'\x1f\x8b\x08\x00\x00\x00\x00\x00\x00\x03'
with open(filename,'wb') as fb:
for chunk in r.iter_content(chunk_size=5):
fb.write(chunk)
【结果】该文件内容同r.text
【备注】一般情况下,应用上方的模式将文本流保存到文件,使用Response.iter_content将会处理大量你直接使用Response.raw不得不处理的。当流下载时,上方是优先推荐的获取内容方式。
【五】定制请求头
这一块我不太熟悉,详见此篇随笔的引用地址