Python爬虫利器Pyppeteer框架简介
off999 2024-12-14 14:24 21 浏览 0 评论
Selenium作为一款知名的WEB自动化测试框架,因其支持绝大多数主流的浏览器,而且提供了丰富的API接口,能方便的通过程序控制来对WEB应用进行各项功能测试。当然很多时候他也作为爬虫工具来从网络上获取相关数据。但是selenium也有其一定缺点,被人吐槽比较多的就是其配置要求比较严格而且经常要更新内核驱动,但是最令人头疼的那就是作为单纯爬虫来说太"重"了,各类驱动、接口都加载上导致其运行速度较慢。
今天给大家推荐一款更为轻量化的自动化框架——Pyppeteer。它其实是Puppeteer的Python实现,它通过DevTools协议来控制Chromium浏览器来实现对页面逻辑的自动化控制,从而可以获取页面内的数据。
结合Puppeteer官网给的介绍简单地来说它相当于是帮你在后台打开了一个浏览器,打开你所需要访问的网页,你可以通过它提供的各种浏览器控制接口来控制它的行为,当然你也可以通过其提供的接口来获取它页面中的内容。另外要说明的是这个“在后台”的浏览器通常成为headless模式,你也可以通过启动参数配置来让它展示在前台来,这样可以在调试阶段实时看到一步步的你程序代码的执行情况。
安装Pyppeteer
pip install pyppeteerPyppeteer库可以直接用pip命令进行安装,这个是很方便的。但是前文提到过Pyppeteer其实是需要控制Chromium浏览器来实现自动化功能的,所以在安装好Pyppeteer库之后还需要我们安装Chromium浏览器,安装过程也是比较简单,只需要在控制台执行“pyppeteer-install”即可。对比Selenium来说还是方便了不少,起码不用再去关心driver啥的了。另外需要说明的是,Chromium浏览器其实也可以不需要手动去安装,第一次运行Pyppeteer程序时,如果检测到没有安装浏览器的话它会自动去下载的。
测试
官方给的测试代码如下,我稍许加了点注释:
import asyncio
from pyppeteer import launch
async def main():
browser = await launch() #打开浏览器
page = await browser.newPage() #打开一个新的页面
await page.goto('https://www.baidu.com') #打开一个网页地址
await page.screenshot({'path': 'example.png'}) #将页面截图
await browser.close() #关闭浏览器
asyncio.get_event_loop().run_until_complete(main())
是不是很简洁明了,和我们手动操作浏览器打开网页的操作逻辑很一致,所以这也是其魅力之一。
需要重点说明下的是Pyppeteer使用了asyncio库,顾名思义它是支持异步IO的,可以方便地应对高并发等场景需求,做爬虫的小伙伴是不是又眼前一亮了。同时也需要说明的是Pyppeteer库对Python版本要求是3.6+,所以小伙伴们使用前一定要注意下自己的Python版本。
Github项目主页:https://github.com/pyppeteer/pyppeteer
Pip项目主页:https://pypi.org/project/pyppeteer/
后续我会针对pyppeteer库的相关特性和用法进行介绍,感兴趣的小伙伴请关注我!
相关推荐
- 电脑主机不启动但通电(电脑主机开机不通电没反应)
-
第1步:首先检查电脑的外部接线是否接好,把各个连线重新插一遍,看故障是否排除。第2步:如果故障依旧,接着打开主机箱查看机箱内有无多余金属物,或主板变形造成的短路,闻一下机箱内有无烧焦的糊味,主板上有无...
- 苹果一体机怎么重装系统(苹果一体机重装系统win10)
-
苹果更换硬盘后,如果您没有创建一个启动磁盘或者使用TimeMachine备份系统,您可以按照以下步骤重新安装操作系统:1.准备一个可用于安装系统的启动磁盘。您可以使用官方提供的macOS安装介质(...
-
- 装系统的u盘怎么制作(装系统怎么制作u盘启动盘)
-
1、下载安装u当家u盘启动盘制作工具,完成之后打开该软件2、将之前准备好的U盘插入电脑,U当家会自动识别并选为默认,如果有多个U盘可以在“选择U盘”的下拉框中选择要制作成U盘启动盘的U盘。3、点击下面的“一键制作”按钮。(如果是电脑主板是U...
-
2025-11-15 07:03 off999
- 台电u盘怎么样
-
感觉台电U盘还是可以的,我知道台电是国内最成功的数码产品制造商之一,是一个致力于IT及消费数码类产品研发、生产、销售及服务的一体化品牌,U盘很好用,用的人很多。威刚是480Mbit/S只是USB2...
- u盘重装系统蓝屏进不去(u盘装系统重启蓝屏)
-
尊敬的用户您好:可按下面的步骤进行系统盘装系统:1.买一张win7光盘,将系统光盘放入光驱里。2.打开电源,然后观察屏幕的提示,在启动系统之前有按“f2进行bios设置。3.设置启动方式。找到boot...
- win快捷键大全(win快捷键大全表)
-
win快捷键:单独按Windows:显示或隐藏“开始”功能表Windows+BREAK:显示“系统属性”对话框Windows+D:显示桌面或恢复桌面Windows+M:最小化所有窗口Windows...
- u盘突然要格式化怎么回事(用着的u盘突然要格式化)
-
U盘提示格式化的原因可能有以下几点:文件系统损坏:U盘的文件系统可能出现损坏,导致无法正常读取和写入数据。病毒感染:U盘可能被病毒感染,病毒会破坏文件系统或隐藏文件。不兼容的文件系统:U盘可能使用了一...
- 路由器pppoe怎么设置(路由器如何设置pppoe上网)
-
移动宽带PPPOE是不用设置的,你只要把帐号和密码填上其他都不选就能上网。但是要注意连接到你电脑的网线是直接经过一个路由器后连接到猫上的,因为我见过有人是这样连接的猫---路由器---路由器---电脑...
- win7桌面图标设置在哪里(win7桌面图标在哪个文件夹)
-
要调出Win7桌面图标,首先需要进入桌面。可以通过点击任务栏上方的“显示桌面”按钮或按下Windows键+D快捷键进入桌面。在桌面上右键单击空白区域,选择“个性化”,然后选择“更改桌面图标”选项。在弹...
- win7手机壁纸(windows7手机桌面主题)
-
1.首先我们打开手机进入到桌面,找到设置图标点击打开。华为手机如何设置自定义锁屏壁纸2.进入到设置界面之后,点击下方的显示选项。华为手机如何设置自定义锁屏壁纸3.然后我们就可以在显示界面中找到壁纸...
- 怎么开启路由器wifi(怎么开启路由器的dhcp功能)
-
把路由器改为开放网络方法如下:1、打开浏览器,在地址栏输入路由器网关IP地址(路由器背后的标签上有,一般是192.168.1.1),输入登录用户名和密码(一般均为admin);2、登录成功后就显示运行...
- win10加载不出来桌面黑屏(window10加载不出来)
-
方法一、如果是遇到了突发性黑屏首先尝试使用Ctrl+Alt+Delete组合键来进行电脑重启一般重启可以解决大部分黑屏故障。win10电脑黑屏按什么键恢复_win10电脑黑屏一键恢复的方法方法...
- 怎么用火绒关闭win安全中心(win10火绒安全软件怎么关闭)
-
一、火绒防火墙关闭方法在电脑上运行火绒软件后,点击首页界面的“防护中心”,在病毒防护界面可以关闭文件、U盘、邮件等保护功能,。系统防护:在该界面可以关闭系统防护功能,。网络防护:可以关闭网络保护等功...
- 微软应用商店下载手机版(微软应用商店在哪下)
-
、在桌面任务栏找到微软应用商店,点击并打开。2、进入页面后点击【应用】,进入应用页面。3、在页面里往下移动,找到热门应用,找到一个软件,点击进入。4、进入页面后,点击【安装】,软件会自动安装,安装完毕...
- win11系统怎么查看电脑配置(win11怎么查看系统版本)
-
答:win11查看电脑配置步骤如下。1.点击下方任务栏的windows图标或者按下键盘“windows键”打开开始菜单。2.在开始菜单中找到“设置”或“settings”,一般是右上角的齿轮状按钮,3...
欢迎 你 发表评论:
- 一周热门
-
-
抖音上好看的小姐姐,Python给你都下载了
-
全网最简单易懂!495页Python漫画教程,高清PDF版免费下载
-
Python 3.14 的 UUIDv6/v7/v8 上新,别再用 uuid4 () 啦!
-
python入门到脱坑 输入与输出—str()函数
-
飞牛NAS部署TVGate Docker项目,实现内网一键转发、代理、jx
-
宝塔面板如何添加免费waf防火墙?(宝塔面板开启https)
-
Python三目运算基础与进阶_python三目运算符判断三个变量
-
(新版)Python 分布式爬虫与 JS 逆向进阶实战吾爱分享
-
慕ke 前端工程师2024「完整」
-
失业程序员复习python笔记——条件与循环
-
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python面向对象编程 (60)
- python 代码加密 (65)
- python串口编程 (77)
- python封装 (57)
- python写入txt (66)
- python读取文件夹下所有文件 (59)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)
