Requests是用python语言基于urllib编写的,采用的是Apache2 Licensed开源协议的HTTP库,如果你看过上篇文章关于urllib库的使用,你会发现,其实urllib还是非常不方便的,而Requests它会比urllib更加方便,可以节约我们大量的工作。(用了requests之后,你基本都不愿意用urllib了)一句话,requests是python实现的最简单易用的HTTP库,建议爬虫使用requests库。
默认安装好python之后,是没有安装requests模块的,需要单独通过pip安装
requests功能详解
总体功能的一个演示
import requests
response = requests.get(“https://www.baidu.com”)
print(type(response))
print(response.status_code)
print(type(response.text))
print(response.text)
print(response.cookies)
print(response.content)
print(response.content.decode(“utf-8”))
我们可以看出response使用起来确实非常方便,这里有个问题需要注意一下:
很多情况下的网站如果直接response.text会出现乱码的问题,所以这个使用response.content
这样返回的数据格式其实是二进制格式,然后通过decode()转换为utf-8,这样就解决了通过response.text直接返回显示乱码的问题.
请求发出后,Requests 会基于 HTTP 头部对响应的编码作出有根据的推测。当你访问 response.text 之时,Requests 会使用其推测的文本编码。你可以找出 Requests 使用了什么编码,并且能够使用 response.encoding 属性来改变它.如:
response =requests.get(“http://www.baidu.com”)
response.encoding=”utf-8″
print(response.text)
不管是通过response.content.decode(“utf-8)的方式还是通过response.encoding=”utf-8″的方式都可以避免乱码的问题发生
各种请求方式
requests里提供个各种请求方式
import requests
requests.post(“http://httpbin.org/post”)
requests.put(“http://httpbin.org/put”)
requests.delete(“http://httpbin.org/delete”)
requests.head(“http://httpbin.org/get”)
requests.options(“http://httpbin.org/get”)
请求
基本GET请求
import requests
response = requests.get(‘http://httpbin.org/get’)
print(response.text)
带参数的GET请求,例子1
import requests
response = requests.get(“http://httpbin.org/get?name=zhaofan&age=23”)
print(response.text)
如果我们想要在URL查询字符串传递数据,通常我们会通过httpbin.org/get?key=val方式传递。Requests模块允许使用params关键字传递参数,以一个字典来传递这些参数,例子如下:
import requests
data = {
“name”:”zhaofan”,
“age”:22
}
response = requests.get(“http://httpbin.org/get”,params=data)
print(response.url)
print(response.text)
上述两种的结果是相同的,通过params参数传递一个字典内容,从而直接构造url
注意:第二种方式通过字典的方式的时候,如果字典中的参数为None则不会添加到url上
解析json
import requests
import json
response = requests.get(“http://httpbin.org/get”)
print(type(response.text))
print(response.json())
print(json.loads(response.text))
print(type(response.json()))
从结果可以看出requests里面集成的json其实就是执行了json.loads()方法,两者的结果是一样的。