百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

python爬虫学习(四):requests的使用

off999 2024-10-08 06:21 32 浏览 0 评论

requests也一个访问网络资源的模块包,不过是python的第三方库,处理url比urllib会更方便一些,而且还有很多实用的高级功能。

安装requests,这里采用pip进行安装:

  • 在windows系统下只需要在命令行输入命令 pip install requests 即可安装。
  • 在 linux 系统下,只需要输入命令 sudo pip install requests ,即可安装。
  • 在 mac系统下,只需要输入命令 pip3 install requests ,即可安装。

安装成功后,如果是在pycharm软件编辑的话,这个时候就有requests的提示了。

如下:


requests的七个主要方法:
  • requests.request() 构造一个请求,支持以下各种方法
  • requests.get() 获取html的主要方法
  • requests.head() 获取html头部信息的主要方法
  • requests.post() 向html网页提交post请求的方法
  • requests.put() 向html网页提交put请求的方法
  • requests.patch() 向html提交局部修改的请求
  • requests.delete() 向html提交删除请求

这里主要讲比较常用的get和post请求方式。

requests.get()

源码:get(url, params=None, kwargs)

url参数:访问地址

Params参数: 网址尾部附加的参数,如http://xxx.xx.com/get?a=xxx&b=xxx 中的a=xxx&b=xxx部分。

kwargs参数:主要是其他可传参数的集合,具体跟urllib.request.urlopen()方法里面的参数类似。我们在源码中可以发现get和post最终都是跳到一个方法进行执行。

def request(self, method, url,
            params=None, data=None, headers=None, cookies=None, files=None,
            auth=None, timeout=None, allow_redirects=True, proxies=None, 
            hooks=None, stream=None, verify=None, cert=None, json=None)

上面的参数即为get和post方法所有可以传的参数。

具体:
import requests
r = requests.get(“http://www.baidu.com“)
print(r.status_code)  #状态码
print(r.text)   #返回内容

这是最简单的访问方法。还有带参的。

import requests
r = requests.get(‘https://www.douban.com/search‘, params={‘q’: ‘python’, ‘cat’: ‘1001’})
print(r.url)   #查看请求的url
print(r.encoding)  #查看请求的编码
print(r.content)  #返回的内容,bytes对象,未解码,r.text是已经解码之后的字符串

另外,如果要传递headers可以这么写

 r = requests.get(‘https://www.douban.com/‘, headers={‘User-Agent’: ‘Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit’})
requests.post()

一些参数传递方式和get方法差不多。传入data参数作为post请求的数据

>>> r = requests.post(‘https://accounts.douban.com/login‘, data={‘form_email’: ‘abc@example.com’, ‘form_password’: ‘123456’})

requests默认使用application/x-www-form-urlencoded对POST数据编码。如果要传递JSON数据,可以直接传入json参数:

params = {‘key’: ‘value’}
r = requests.post(url, json=params) # 内部自动序列化为JSON

类似的,上传文件需要更复杂的编码格式,但是requests把它简化成files参数:

>>> upload_files = {‘file’: open(‘report.xls’, ‘rb’)}
>>> r = requests.post(url, files=upload_files)

要在请求中传入Cookie,只需准备一个dict传入cookies参数:

>>> cs = {‘token’: ‘12345’, ‘status’: ‘working’}
>>> r = requests.get/post(url, cookies=cs)

最后,要指定超时,传入以秒为单位的timeout参数:

>>> r = requests.get/post(url, timeout=2.5) # 2.5秒后超时

获取响应头,可以通过r.headers获取,另外通过r.headers[key]获取具体某一个头部信息。获取cookies类似。

requests.request()

该方法可以实现get也可以实现post.通过首个参数method传递‘GET’或‘POST’进行区分,其余参数与上述相同。

r=requests.request(‘GET’,‘https://www.douban.com/search‘,params={‘q’: ‘python’, ‘cat’: ‘1001’})

相关推荐

笔记本电脑系统修复软件(笔记本电脑程序修复)

1、超级兔子2013系统修复软件超级兔子是一款完整的系统维护工具。拥有电脑系统评测、垃圾清理和注册表清理、可疑文件和插件检测、网页防护等功能,同时自带一些实用的系统工具,可清理你大多数的文件、注册表里...

联想保修服务包括哪些(联想保修都保修什么)

1、保修36个月的硬件包括:CPU、内存。2、保修24个月的硬件包括:主板、显卡、LCD屏、硬盘、电源适配器、键盘、鼠标模块。3、保修12个月的硬件包括:LCD之附件、光驱、DVD、CDR/W、软驱...

系统科学大会(中国系统科学学会)

2021年各种科学大会的召开时间取决于疫情的发展和国家政策的调整。一些大型的国际科学会议可能会推迟或者采用线上形式进行,以保障参会人员的安全和健康。同时,一些国内的学术会议也会受到疫情的影响,需要推迟...

win10系统下载的内容在哪(win10下载的软件在哪个文件夹)

进入C:\Windows\SoftwareDistribution\Download目录下,通过win10应用商店中下载的安装包都放在此目录下。进入C:\Windows\SoftwareDistrib...

下载原版xp系统光盘(xp光盘系统安装教程怎么安装)

方法步骤步骤如下:1、首先打开计算机,在电脑光驱上放入XP光盘,启动电脑后不停按F12、F11、Esc等启动热键,在弹出的启动菜单中选择DVD选项,回车。2、进入光盘主菜单,按数字2或点击选项2运行w...

windows7中文版下载安装(windows7安装包下载)

谢邀,如果你戳设置-时间和语言-区域和语言,右边的语言提示“只允许使用一种语言包”,那么你的系统就是家庭中文版。家庭中文版限定系统界面只能使用简体中文显示,其他功能则与普通家庭版没有区别,也可以使用其...

win7开机按f2怎么重装系统(win7开机按f12怎么重装系统)

开机或重启时,在进入Windows前按F2进入BIOS。  ←→移动到第三个好像是BOOT。  然后将EXTENELBOOT选项设置为ENABLE  最后按F5将第一启动项目设置为EXTENEL...

win10驱动管理(win10驱动程序)
win10驱动管理(win10驱动程序)

win10由于联网后会自动安装驱动,如果自动安装驱动没出现问题,即可视为最佳驱动,若出现问题,卸载出问题的驱动,然后去查自己主板型号,在主板供应商官网下载对应驱动即是最佳01Windows10驱动更新调整当前当你插入连接即插即用(Pn...

2025-12-29 05:51 off999

手机上怎么找qq邮箱登录(用手机怎么找到qq邮箱)

入口是“联系人”选项卡。qq邮箱手机在QQ主菜单中选择下方的“联系人”选项卡;3、在“联系人”中选取“公众号”选项卡;4、在公众号中菜单中找到或搜索“QQ邮箱提醒”,点击进入;5、点击“进入邮箱”;6...

amd显卡控制面板

AMD显卡控制面板是用来管理你的AMD显卡的,可以在控制面板中进行设置一些简单的调整,来提升显卡性能和效果。1、先打开AMD控制面板。2、打开“垂直同步(V-SYNC)”功能,可调整细节,改善影像流畅...

win10老是未响应卡死(window10总是未响应)

具体方法:1、如果win10中的应用程序出现不响应的情况,应该是应用程序加载失败了。可以通过重置方法来解决win10应用程序无响应。2、登录win10系统,用管理员身份运行Powershell(可在C...

usb安装系统步骤(USB安装系统步骤)

1.准备一张U盘,将联想官网下载的系统镜像文件复制到U盘中;2.将U盘插入联想S41U电脑,重启电脑,按F12进入BIOS设置,将U盘设置为启动项;3.重启电脑,进入U盘安装界面,按提示操作,完成系统...

win98安装教程(win98iso怎么安装)

如何安装windows98  一、具体安装步骤  备份好重要文件之后,就可以安装windows98了。  第一步:启动安装程序。  用户如果原来已安装了windows95/97/98,现在拟对其进行升...

雨林木风win7安装(雨林木风win732位安装教程)

  安装步骤如下:  1、光盘放入光驱,复制光盘上的win7.gho和安装系统.exe到硬盘非C盘的文件夹;(gho文件名可以是其他名字,后缀为gho,体积最大的就是。)  2、双击安装系统.exe;...

win10解绑管理员账户(win10管理员账户怎么取消开机密码)

要解除Windows10电脑上的管理员权限,您需要进行以下操作:1.打开“控制面板”:右键单击“开始”按钮,然后选择“控制面板”。2.进入“用户账户”:在控制面板中,选择“用户账户”。3.点击...

取消回复欢迎 发表评论: