python爬虫利器之requests库的用法(超全面的爬取网页案例)

时间:2021-08-13 01:46:01

requests库

利用pip安装:
pip install requests

基本请求

  1. req = requests.get("https://www.baidu.com/")
  2. req = requests.post("https://www.baidu.com/")
  3. req = requests.put("https://www.baidu.com/")
  4. req = requests.delete("https://www.baidu.com/")
  5. req = requests.head("https://www.baidu.com/")
  6. req = requests.options(https://www.baidu.com/)

1.get请求

参数是字典,我们可以传递json类型的参数:

  1. import requests
  2. from fake_useragent import UserAgent#请求头部库
  3. headers = {"User-Agent":UserAgent().random}#获取一个随机的请求头
  4. url = "https://www.baidu.com/s"#网址
  5. params={
  6. "wd":"豆瓣" #网址的后缀
  7. }
  8.  
  9. requests.get(url,headers=headers,params=params)

python爬虫利器之requests库的用法(超全面的爬取网页案例)

返回了状态码,所以我们要想获取内容,需要将其转成text:

  1. #get请求
  2.  
  3. headers = {"User-Agent":UserAgent().random}
  4. url = "https://www.baidu.com/s"
  5. params={
  6. "wd":"豆瓣"
  7. }
  8.  
  9. response = requests.get(url,headers=headers,params=params)
  10. response.text

2.post 请求

参数也是字典,也可以传递json类型的参数:

  1. import requests
  2. from fake_useragent import UserAgent
  3.  
  4. headers = {"User-Agent":UserAgent().random}
  5.  
  6. url = "https://www.baidu.cn/index/login/login" #登录账号密码的网址
  7. params = {
  8. "user":"1351351335",#账号
  9. "password":"123456"#密码
  10. }
  11.  
  12. response = requests.post(url,headers=headers,data=params)
  13. response.text

python爬虫利器之requests库的用法(超全面的爬取网页案例)

因为这里需要一个登录的网页,我这里就随便用了一个,没有登录,所以显示的结果是这样的,如果想要测试登录的效果,请找一个登录的页面去尝试一下。

3.IP代理

采集时为避免被封IP,经常会使用代理,requests也有相应 的proxies属性。

  1. #IP代理
  2.  
  3. import requests
  4. from fake_useragent import UserAgent
  5.  
  6. headers = {"User-Agent":UserAgent().random}
  7. url = "http://httpbin.org/get" #返回当前IP的网址
  8.  
  9. proxies = {
  10. "http":"http://yonghuming:123456@192.168.1.1:8088"#http://用户名:密码@IP:端口号
  11. #"http":"https://182.145.31.211:4224"# 或者IP:端口号
  12. }
  13.  
  14. requests.get(url,headers=headers,proxies=proxies)

代理IP可以去:快代理去找,也可以去购买。
http://httpbin.org/get。这个网址是查看你现在的信息:

python爬虫利器之requests库的用法(超全面的爬取网页案例)

4.设置访问超时时间

可以通过timeout属性设置超时时间,一旦超过这个时间还没获取到响应内容,就会提示错误。

  1. #设置访问时间
  2. requests.get("http://baidu.com/",timeout=0.1)

python爬虫利器之requests库的用法(超全面的爬取网页案例)

5.证书问题(SSLError:HTTP)

ssl验证。

  1. import requests
  2. from fake_useragent import UserAgent #请求头部库
  3.  
  4. url = "https://www.12306.cn/index/" #需要证书的网页地址
  5. headers = {"User-Agent":UserAgent().random}#获取一个随机请求头
  6.  
  7. requests.packages.urllib3.disable_warnings()#禁用安全警告
  8. response = requests.get(url,verify=False,headers=headers)
  9. response.encoding = "utf-8" #用来显示中文,进行转码
  10. response.text

python爬虫利器之requests库的用法(超全面的爬取网页案例)

6.session自动保存cookies

  1. import requests
  2. from fake_useragent import UserAgent
  3.  
  4. headers = {"User-Agent":UserAgent().chrome}
  5. login_url = "https://www.baidu.cn/index/login/login" #需要登录的网页地址
  6. params = {
  7. "user":"yonghuming",#用户名
  8. "password":"123456"#密码
  9. }
  10. session = requests.Session() #用来保存cookie
  11.  
  12. #直接用session 歹意requests
  13. response = session.post(login_url,headers=headers,data=params)
  14.  
  15. info_url = "https://www.baidu.cn/index/user.html" #登录完账号密码以后的网页地址
  16. resp = session.get(info_url,headers=headers)
  17. resp.text

因为我这里没有使用需要账号密码的网页,所以显示这样:

python爬虫利器之requests库的用法(超全面的爬取网页案例)

我获取了一个智慧树的网页

  1. #cookie
  2.  
  3. import requests
  4. from fake_useragent import UserAgent
  5.  
  6. headers = {"User-Agent":UserAgent().chrome}
  7. login_url = "https://passport.zhihuishu.com/login?service=https://onlineservice.zhihuishu.com/login/gologin" #需要登录的网页地址
  8. params = {
  9. "user":"12121212",#用户名
  10. "password":"123456"#密码
  11. }
  12. session = requests.Session() #用来保存cookie
  13.  
  14. #直接用session 歹意requests
  15. response = session.post(login_url,headers=headers,data=params)
  16.  
  17. info_url = "https://onlne5.zhhuishu.com/onlinWeb.html#/stdetInex" #登录完账号密码以后的网页地址
  18. resp = session.get(info_url,headers=headers)
  19. resp.encoding = "utf-8"
  20. resp.text

python爬虫利器之requests库的用法(超全面的爬取网页案例)

7.获取响应信息

代码 含义
resp.json() 获取响应内容 (以json字符串)
resp.text 获取相应内容(以字符串)
resp.content 获取响应内容(以字节的方式)
resp.headers 获取响应头内容
resp.url 获取访问地址
resp.encoding 获取网页编码
resp.request.headers 请求头内容
resp.cookie 获取cookie

到此这篇关于python爬虫利器之requests库的用法(超全面的爬取网页案例)的文章就介绍到这了,更多相关python爬虫requests库用法内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://blog.csdn.net/sjjsaaaa/article/details/111237071