Python爬虫连载10-Requests模块、Proxy代理

1、Request模块python

1.HTTP for Humans,更简洁更友好git

2.继承了urllib全部的特征github

3.底层使用的是urllib3web

4.​开源地址:https://github.com/requests/requestsjson

5.中文文档​:https://requests.readthedocs.io/zh_CN/latest/安全

6.先安装这个包:pip install requests微信

7.get请求post

(1)requests.get()学习

(2)requests.request("get",url)大数据

(3)能够带有headers和params参数

8.get返回内容

 

import requests

​

#两种请求

url = "http://www.baidu.com/s?"

rsp = requests.get(url)

# print(rsp.text)
#使用get请求

rsp = requests.request("GET",url)

# print(rsp.text)

#拿到的结果都是同样的
"""

使用参数headers和params来研究返回结果

"""

kw = {

    "wd":"python中文文档"

}

headers = {

    "User-Agent":"Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/80.0.3987.116 Safari/537.36"

}

rsp=requests.get(url,params=kw,headers=headers)

print(rsp.text)

print("=========================")

print(rsp.content)

print("=========================")

print(rsp.url)

print(rsp.encoding)

print(rsp.status_code)

 

2、post

data,headers要求使用dict

 

import requests

from urllib import parse

import json

url = "http://www.baidu.com/s?"

data = {

    "kw":"girl"

}

# data = parse.urlencode(data).encode("utf-8")

headers = {

    "User-Agent":"Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/80.0.3987.116 Safari/537.36"

}

rsp = requests.post(url,data=data,headers=headers)

print(rsp.text)

# print(rsp.json())

3、proxy代理

1.代理有可能会报错,若是使用人数多,考虑到安全问题,可能会被强行关闭

2.用户验证

(1)代理验证​:可能须要HTTP basic Auth

 

proxy = {"http":"china:123456@192.168.1.123:458"}

#格式为   用户名:密码@代理地址:端口地址

rsp = requests.get("http://baidu.com",proxies=proxy)

 

 

(2)web客户端验证

若是遇到web客户端验证,须要添加auth=(用户名,密码)

 

auth = {"test","123456"}#受权信息

rsp = requests.get("http://www.baidu.com",auth=auth)

 

 

4、源码

Reptitle10_1_Requests.py

Reptitle10_2_Post.py

https://github.com/ruigege66/PythonReptile/blob/master/Reptitle10_1_Requests.py

https://github.com/ruigege66/PythonReptile/blob/master/Reptitle10_2_Post.py

2.CSDN:https://blog.csdn.net/weixin_44630050

3.博客园:https://www.cnblogs.com/ruigege0000/

4.欢迎关注微信公众号:傅里叶变换,我的公众号,仅用于学习交流,后台回复”礼包“,获取大数据学习资料

相关文章
相关标签/搜索