Requests提供了几乎所有HTTP动词的功能:GET,OPTIONS, HEAD,POST,PUT,PATCH和DELETE。
动词GET-查看提交信息
HTTP GET是一个幂等的方法,从给定的URL返回一个资源。因而,当你试图从一个web位置获取数据之时,你应该使用这个动词。
举个栗子:从Github上获取关于一个特定commit的信息
>>> import requests >>> r = requests.get('https://api.github.com/repos/kennethreitz/requests/git/commits/a050faf084662f3a352dd1a941f2c7c9f886d4ad')
我们应该确认Github是否正确响应。如果正确响应,我们想弄清响应内容是什么类型的。
可见,GitHub返回了JSON数据,非常好,这样就可以使用 r.json
方法把这个返回的数据解析成Python对象。
# 将json对象转成python字典 >>> commit_data = r.json() # 获取所有键 >>> print commit_data.keys() [u'committer', u'author', u'url', u'tree', u'html_url', u'sha', u'parents', u'me ssage'] # 打印commiter键的内容 >>> print commit_data[u'committer'] {u'date': u'2012-05-10T18:10:50Z', u'name': u'Kenneth Reitz', u'email': u'me@ken nethreitz.com'} # 打印message键的内容 >>> print commit_data[u'message'] makin' history
OPTIONS动词-查看接口方法
如果服务器正确实现了OPTIONS,那么服务器应该在响应头中返回允许用户使用的HTTP方法。
>>> verbs = requests.options('http://a-good-website.com/api/cats') >>> print verbs.headers['allow'] GET,HEAD,POST,OPTIONS
但是通常好多服务器并未实现OPTIONS方法。这是一个恼人的疏忽,但没关系,那我们可以使用枯燥的文档来查看接口支持的方法。
POST动词-发表评论
发表评论,这里需要身份验证。
>>> from requests.auth import HTTPBasicAuth >>> auth = HTTPBasicAuth('fake@example.com', 'not_a_real_password') >>> r = requests.post(url=url, data=body, auth=auth) >>> r.status_code 201 >>> content = r.json() >>> print(content[u'body']) Sounds great! I'll get right on it.