在使用 Requests 发送请求后,会得到一个 Response 响应对象。除了常用的 text
和 content
属性之外,Response 对象还提供了许多其他常用的属性和方法。
Response 响应对象的常用属性
下表列出了 Response 响应对象的常用属性:
属性 | 描述 |
---|---|
url |
响应的 URL |
status_code |
响应状态码 |
headers |
响应头信息 |
request.headers |
响应对应请求的请求头 |
request._cookies |
响应对应请求的 Cookie |
cookies |
响应的 Cookie(经过了 set-cookie) |
ok |
判断响应是否成功 |
is_redirect |
判断是否存在重定向 |
content |
响应内容(字节类型) |
text |
响应内容(文本类型) |
encoding |
响应的编码 |
elapsed |
响应的时间 |
history |
响应的重定向历史记录 |
Response 响应对象的常用方法
下表列出了 Response 响应对象的常用方法:
方法 | 描述 |
---|---|
json() |
将 JSON 响应内容转换为 Python 对象(字典或列表) |
close() |
关闭响应连接,释放资源 |
iter_content() |
以迭代器方式逐块获取响应内容的字节数据 |
iter_lines() |
以迭代器方式逐行获取响应内容的文本数据 |
raise_for_status() |
如果响应状态码不是 200,会抛出异常 |
is_permanent_redirect() |
判断是否是永久重定向(301状态码) |
is_redirect() |
判断是否是重定向(3xx 状态码) |
is_client_error() |
判断是否是客户端错误(4xx 状态码) |
is_server_error() |
判断是否是服务器错误(5xx 状态码) |
iter_any() |
以迭代器方式逐个字节获取响应内容的任何数据 |
请注意,以上属性和方法只是 Response 响应对象的一部分。根据实际需求,您可能会使用到其中的一些或多个。
示例
import requests
# 目标url
url = 'https://www.baidu.com'
# 向目标url发送get请求
response = requests.get(url)
# 响应的状态码
status_code = response.status_code
# 响应的URL,有时候响应的URL和请求的URL并不一致
response_url = response.url
# 响应的内容(字节类型)
content = response.content
# 响应的内容(文本类型)
text = response.text
# 响应头信息
headers = response.headers
# 响应对象的请求头信息
request_headers = response.request.headers
# 响应的cookies(经过了set-cookie动作)
cookies = response.cookies
# 响应对象的请求携带的cookies
request_cookies = response.request._cookies
# 判断响应是否成功
is_success = response.ok
# 判断是否存在重定向
is_redirect = response.is_redirect
# 判断是否存在内容
has_content = response.content is not None
# 判断是否存在文本内容
has_text = response.text is not None
# 获取响应头中的特定信息
content_type = response.headers.get('content-type')
# 获取响应时间
response_time = response.elapsed.total_seconds()
# 获取响应的编码
encoding = response.encoding
# 获取响应的历史记录,即重定向路径
history = response.history
# 将JSON响应内容转换为Python对象(字典或列表)
json_data = response.json()
# 关闭响应连接,释放资源
response.close()