import requests
Python 标准库中的 urllib2
模块提供了你所需要的大多数 HTTP
功能,但是它的 API
不是特别方便使用。
requests
模块号称 HTTP for Human
,它可以这样使用:
r = requests.get("http://httpbin.org/get")
r = requests.post('http://httpbin.org/post', data = {'key':'value'})
r = requests.put("http://httpbin.org/put")
r = requests.delete("http://httpbin.org/delete")
r = requests.head("http://httpbin.org/get")
r = requests.options("http://httpbin.org/get")
假如我们想访问 httpbin.org/get?key=val
,我们可以使用 params
传入这些参数:
payload = {'key1': 'value1', 'key2': 'value2'}
r = requests.get("http://httpbin.org/get", params=payload)
查看 url
:
print(r.url)
Requests
会自动解码来自服务器的内容。大多数 unicode
字符集都能被无缝地解码。
r = requests.get('https://github.com/timeline.json')
print r.text
查看文字编码:
r.encoding
每次改变文字编码,text
的内容也随之变化:
r.encoding = "ISO-8859-1"
r.text
Requests
中也有一个内置的 JSON
解码器处理 JSON
数据:
r.json()
如果 JSON
解码失败, r.json
就会抛出一个异常。
r = requests.get('http://httpbin.org/get')
r.status_code
r.headers['Content-Type']