[包计划] requests

本文全面介绍了Python中的Requests库,一个简单易用的网络请求库。包括如何发送各种类型的HTTP请求,处理URL参数,解析响应内容,定制请求头,处理文件上传,响应状态码,响应头,Cookie操作,重定向与请求历史,以及超时和异常处理。

requests

Python 中一个易用的网络请求库

来源

使用

发送请求
r = requests.get('https://api.github.com/events')
r = requests.post('http://httpbin.org/post', data = {'key':'value'})
r = requests.put('http://httpbin.org/put', data = {'key':'value'})
r = requests.delete('http://httpbin.org/delete')
r = requests.head('http://httpbin.org/get')
r = requests.options('http://httpbin.org/get')
传递 URL 参数
# 字典里值为 None 的键都不会被添加到 URL 的查询字符串里
payload = {'key1': 'value1', 'key2': 'value2'}
r = requests.get("http://httpbin.org/get", params=payload)
响应内容
import requests
r = requests.get('https://api.github.com/events')
print(r.text)  # [{"id":"8462576403"}]
print(r.encoding)  # utf-8
二进制响应内容
import requests
r = requests.get('https://api.github.com/events')
print(r.content)
JSON 响应内容
import requests
r = requests.get('https://api.github.com/events')
print(r.json())  # [{'id': '8462617752'}]
原始响应内容
import requests
r = requests.get('https://api.github.com/events', stream=True)
print(r.raw)  # <urllib3.response.HTTPResponse object at 0x10c813550>
定制请求头
import requests
url = 'https://api.github.com/some/endpoint'
headers = {'user-agent': 'my-app/0.0.1'}
r = requests.get(url, headers=headers)
print(r)  # <Response [404]>
复杂的 POST 请求
import requests
import json

# 表单
payload = {'key1': 'value1', 'key2': 'value2'}
r = requests.post("http://httpbin.org/post", data=payload)
print(r.text)

# JSON
url = 'https://api.github.com/some/endpoint'
payload = {'some': 'data'}
r = requests.post(url, data=json.dumps(payload))
print(r.text)

# JSON   2.4.2 版的新加功能
url = 'https://api.github.com/some/endpoint'
payload = {'some': 'data'}
r = requests.post(url, json=payload)
print(r.text)
POST一个多部分编码(Multipart-Encoded)的文件
import requests

url = 'http://httpbin.org/post'
files = {'file': open('test.txt', 'rb')}

r = requests.post(url, files=files)
print(r.text)
响应状态码
import requests

r = requests.get('http://httpbin.org/get')
print(r.status_code)  # 200

print(requests.codes.ok)  # 常量,代表 200
print(requests.codes.not_found)  # 常量,代表 404


bad_r = requests.get('http://httpbin.org/status/404')
print(bad_r.status_code)  # 404
bad_r.raise_for_status()  # 错误请求 抛出异常
响应头
import requests

r = requests.get('http://httpbin.org/get')
print(r.headers)
print(r.headers['Content-Type'])  # application/json
print(r.headers['content-type'])  # application/json
import requests

#  获取 cookie
url = 'http://httpbin.org/cookies'
r = requests.get(url)
print(r.cookies)

#  设置 cookie
url = 'http://httpbin.org/cookies'
cookies = dict(cookies_are='working')
r = requests.get(url, cookies=cookies)
print(r.text)
重定向与请求历史
import requests
# 追踪重定向
r = requests.get('http://github.com')
print(r.history)  # [<Response [301]>]

# 禁用重定向
r = requests.get('http://github.com', allow_redirects=False)
print(r.status_code)  # 301
超时
import requests
r = requests.get('http://github.com', timeout=0.001)
错误与异常
  • 遇到网络问题时,Requests 会抛出一个 ConnectionError 异常。
  • 如果 HTTP 请求返回了不成功的状态码, Response.raise_for_status() 会抛出一个 HTTPError 异常。
  • 若请求超时,则抛出一个 Timeout 异常。
  • 若请求超过了设定的最大重定向次数,则会抛出一个 TooManyRedirects 异常。
  • 所有 Requests 显式抛出的异常都继承自 requests.exceptions.RequestException

转载于:https://www.cnblogs.com/aaronzhou001/p/9835880.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值