使用requests请求后的响应内容

使用Requests进行get请求或post请求后,requests会返回一个Response对象;

这个Response对象包含许多我们需要的东西;

response = requests.get('https://www.baidu.com')

状态码

Response对象有一个status_code属性,它表示服务器返回的状态码:

print(response.status_code)

200表示服务器成功接受了我们的请求并返回;404表示请求的页面不存在;

返回的内容

你可以使用text属性获取服务器响应的内容:

response.text

使用text属性读取的内容都已经被Requests自动解码。大多数的字符集都能被Requests正确的解码。

请求发出后,Requests 会基于 HTTP 头部对响应的编码作出有根据的推测。当你访问response.text之时,Requests 会使用其推测的文本编码。你可以找出 Requests 使用了什么编码,并且能够使用response.encoding属性来改变它:

如果你改变了编码,每次访问.text时,Requests都会使用.encoding的新值;

如果你创建了自己的编码,你应该使用response.content来获取未被解码的二进制内容;

Requests会自动解码使用gzip或deflate进行编码压缩的数据。

读取JSON响应内容

Requests内置了一个JSON解码器,是你读取JSON内容变得非常简单:

response.json()

json()方法会返回一个JSON对象;如果JSON解码失败,它会抛出一个ValueError: No JSON object could be decoded异常

原始RAW流

如果你想获取服务器返回的原始数据流,你可以使用response.raw,它将返回一个HTTPResponse对象,你可以使用该对象的read()方法读取内容。

如果你确实要这么干,你应该在最初的请求中设置stream=True

response = requests.get('https://www.baidu.com/',stream=True)
response.raw.read(10)

当数据过大时,应使用response.iter_content()方法来处理。

将完整的数据保存为文件:

with open(filename, 'wb') as fd:
    for chunk in response.iter_content(chunk_size):
        fd.write(chunk)

原创内容,如需转载,请注明出处;

本文地址: https://www.perfcode.com/p/requests-response.html

分类: 计算机技术
推荐阅读:
PySide6 style()函数详细教程 Pyside6.QtWidgets.QApplication类的成员函数style()用于返回程序当前使用的style对象;
Rust中的Fn、FnOnce、FnMut闭包详解 闭包会自动实现Fn、FnOnce、FnMut这三个trait中的任意一个,这取决于闭包在调用过程中对捕获变量的使用;
spim:(parser) Label is defined for the second time 解决方法 在使用QtSpim读取汇编语言文件时提示:Label is defined for the second time on line xx of file xxx main:,出现这个错误是因为你没有在载入文件前初始化你的模拟器;
Linux一条命令删除文件中的重复项 在Linux系统中,如果你想给一个包含重复项(以行为一个单位)的文件去重,那么你只需要一条命令即可实现;
编程中foo、bar、baz的含义 在编程中,foo、bar和baz通常被用作示例变量名。它们是一种惯用的命名习惯,通常被用于示例代码或临时代码片段中,表示没有特定含义的变量名或函数名。
Windows和Linux系统启用IP转发 在Windows系统下启用IP转发,需要通过修改注册表来实现;Linux系统只需将系统下的/proc/sys/net/ipv4/ip_forward文件值修改为1;