新一代爬虫利器Python|新一代爬虫利器Python Playwright详解
目录
- 安装方式
- 特点
- 使用方式
- 代码生成
- 选择器
- 事件监听
- 总结
在Pyppeteer已经不再维护的年代,拥有Playwright这个开源工具是非常棒的选择,文档丰富,功能强大。
安装方式
conda config --add channels conda-forgeconda config --add channels microsoftconda install playwrightplaywright install
上述命令的具体运行过程是下载Playwright并将其打包为Chromium、Firefox和Webkit安装浏览器二进制文件。
特点
- Playwright支持当前所有主流浏览器,包括Chrome和Edge(基于Chromium)、Firefox、Safari(基于Webkit),提供完善的自动化控制的API。
- Playwright支持移动端页面的测试,使用设备模拟技术可以在移动web浏览器中测试响应式web应用程序。
- Playwright支持所有浏览器的Headless模式和非Headless模式的测试。
- Playwright的安装配置非常的简单,安装过程中会自动安装对应浏览器的驱动,不需要额外的配置WebDriver等。
- Playwright提供了大量的与自动化相关的API,当页面加载时会自动等待对应节点的加载,大大的简化了编写API的难度。
使用方式 在python脚本中导入Playwright,并启动3种浏览器(Chromium、Friefox和webkit)的其中一种。Playwright支持两种编写模式,一种是Pyppeter一样的异步模式,另一种是像Selenium一样的同步模式,我们可以根据实际的需要选择不同的模式。
下面我们先来看看一个基本 同步模式的例子:
from playwright.sync_api import sync_playwrightwith sync_playwright() as p:for browser_type in [p.chromium, p.firefox, p.webkit]:browser = browser_type.launch(headless=False)page = browser.new_page()page.goto("https://www.baidu.com")page.screenshot(path=f"screenshot-{browser_type.name}.png")print(page.title())browser.close()
首先在这里我们导入了sync_playwright方法,然后调用这个方法,该方法返回的是一个
PlaywrightContextManager
对象,可以将其理解为浏览器的上下文管理器,这里将其赋值给变量p。接着调用PlaywrightContextManager对象的chromium、firefox、webkit浏览器实例,接着使用for循环依次去执行它们的launch方法,同时设置headless为False。这里有一个注意点:如果launch没有设置为Flase,默认是无头模式启动浏览器,我们看不到任何的窗口。launch方法返回的是一个浏览器(Browser)对象,我们将其复制为browser变量,然后调用new_page方法,相当于是新建一个选显卡,返回page对象并赋值给变量page,接下来就是调用page对象的一系列自动化API进行操作。当页面加载完毕之后生成截图、控制台输出结果就退出,上面的代码,调用了page对象的两个方法:
1、
screenshot
:参数传一个文件的名称,这样截图就会自动保存为该文件的名称。2、
title
:返回页面的标题。这时当前目录便会产生三个截图文件,都是百度的首页,文件名中都带有浏览器的名称,如图所示:
文章图片
控制台运行结果:
百度一下,你就知道除了上面所描述的同步模式之外,Playwright还支持异步模式,如果在项目中使用了asyncio,那么就应该是考虑要采用异步模式,使用异步的API,写法如下:
百度一下,你就知道
百度一下,你就知道
import asynciofrom playwright.async_api import async_playwrightasync def main():async with async_playwright() as p:for browser_type in [p.chromium, p.firefox, p.webkit]:browser = await browser_type.launch()page = await browser.new_page()await page.goto("https://www.baidu.com")await page.screenshot(path=f"screenshot-{browser_type.name}.png")print(await page.title())await browser.close()asyncio.run(main())
从上面的代码可以看出,整个写法和同步模式是很相似的。
注意:
? 1、导入的是async_playwright方法
? 2、在写法上添加 async/await 关键字。
代码生成 Playwright还有一个强大的功能,那就是可以录制我们在浏览器的操作,并将操作时的代码自动生成。这个功能可以通过Playwright命令调用codegen来实现,我们先看看codegen命令都有什么参数。
playwright codegen --help
结果类似如下:
Usage: npx playwright codegen [options] [url]在上面可以看到有几个选项,比如
open page and generate code for user actions
Options:
-o, --outputsaves the generated script to a file
--targetlanguage to generate, one of javascript, test, python, python-async, csharp (default:
"python")
-b, --browserbrowser to use, one of cr, chromium, ff, firefox, wk, webkit (default: "chromium")
--channelChromium distribution channel, "chrome", "chrome-beta", "msedge-dev", etc
--color-schemeemulate preferred color scheme, "light" or "dark"
--deviceemulate device, for example "iPhone 11"
--geolocationspecify geolocation coordinates, for example "37.819722,-122.478611"
--ignore-https-errors ignore https errors
--load-storageload context storage state from the file, previously saved with --save-storage
--langspecify language / locale, for example "en-GB"
--proxy-server specify proxy server, for example "http://myproxy:3128" or "socks5://myproxy:8080"
--save-storagesave context storage state at the end, for later use with --load-storage
--save-tracerecord a trace for the session and save it to a file
--timezone
- -o表示输出代码文件的名称;
- –target表示所使用的语言,默认是python,即会生成同步模式的操作代码,如果传入的是python-async则会生成异步模式的操作代码;
- -b表示使用的浏览器类型,默认是Chrome浏览器;
- –device可以模拟使用手机浏览器;
- –lang表示设置浏览器语言,
- –timeout可以设置页面加载超时时间。
playwright codegen -o test3.py --target python-async
可以看到浏览器还会高亮显示正在操作的节点,同时还显示了节点名称。
文章图片
在操作的过程中代码是实时变化的。操作完毕之后即可关闭浏览器,Playwright会生成一个test3.py文件,内容如下:
import asynciofrom playwright.async_api import Playwright, async_playwrightasync def run(playwright: Playwright) -> None:browser = await playwright.chromium.launch(headless=False)context = await browser.new_context()# Open new pagepage = await context.new_page()# Go to https://www.baidu.com/await page.goto("https://www.baidu.com/")# Click input[name="wd"]await page.click("input[name=\"wd\"]")# Click input[name="wd"]await page.click("input[name=\"wd\"]")# Fill input[name="wd"]await page.fill("input[name=\"wd\"]", "如何榜上富婆")# Click text=百度一下# async with page.expect_navigation(url="https://www.baidu.com/s?ie=utf-8&f=8&rsv_bp=1&rsv_idx=1&tn=baidu&wd=%E5%A6%82%E4%BD%95%E6%A6%9C%E4%B8%8A%E5%AF%8C%E5%A9%86&fenlei=256&rsv_pq=ca59e3ec000cf6aa&rsv_t=5f82kcndi6iqNSwqOVo5sd%2BHSoqhzQHKLGVs1HFegxx02UtWAA5gHQbWBfw&rqlang=cn&rsv_enter=0&rsv_dl=tb&rsv_sug3=24&rsv_sug1=14&rsv_sug7=100&rsv_btype=i&prefixsug=%25E5%25A6%2582%25E4%25BD%2595%25E6%25A6%259C%25E4%25B8%258A%25E5%25AF%258C%25E5%25A9%2586&rsp=4&inputT=8686&rsv_sug4=68370&rsv_jmp=fail"):async with page.expect_navigation():await page.click("text=百度一下")# assert page.url == "https://www.baidu.com/s?ie=utf-8&f=8&rsv_bp=1&rsv_idx=1&tn=baidu&wd=%E5%A6%82%E4%BD%95%E6%A6%9C%E4%B8%8A%E5%AF%8C%E5%A9%86&fenlei=256&rsv_pq=ca59e3ec000cf6aa&rsv_t=5f82kcndi6iqNSwqOVo5sd%2BHSoqhzQHKLGVs1HFegxx02UtWAA5gHQbWBfw&rqlang=cn&rsv_enter=0&rsv_dl=tb&rsv_sug3=24&rsv_sug1=14&rsv_sug7=100&rsv_btype=i&prefixsug=%25E5%25A6%2582%25E4%25BD%2595%25E6%25A6%259C%25E4%25B8%258A%25E5%25AF%258C%25E5%25A9%2586&rsp=4&inputT=8686&rsv_sug4=68370"# Close pageawait page.close()# ---------------------await context.close()await browser.close()async def main() -> None:async with async_playwright() as playwright:await run(playwright)asyncio.run(main())
可以看到这里的代码和我们之前编写的代码基本类似,而且也是完全可以运行的,运行之后就可以看到它又复现了我们刚才的动作。
另外这里的new_page并不是通过
browser
调用的,而是通过context
变量调用的,context
又是通过Browser
对象调用的。这里的context变量相当于一个BrowserContext
对象,它是一个类似于隐身模式的独立上下文环境,其运行资源是隔离的,保证互不干扰。选择器 Playwright的文档非常的丰富,可以直接参考https://playwright.dev/python/docs/selectors
事件监听 page对象提供了一个on方法,它可以用来监听页面中各个事件,比如
close
、console
、load
、request
、response
等等。比如我们可以监听response事件,response事件可以在每次网络请求得到响应的时候触发,我们可以设置对应的回调方法获取对应的Response的全部信息。
from playwright.sync_api import sync_playwrightdef on_response(response):print(f'Statue {response.status}:{response.url}')with sync_playwright() as p:browser = p.chromium.launch(headless=False)page = browser.new_page()page.on('response', on_response)page.goto('https://www.kenshujun.cn/')page.wait_for_load_state('networkidle')browser.close()
创建page对象之后,就开始监听response事件,同时将回调方法设置为
on_response
,on_response
对象接受一个参数,然后把状态码和连接都输出来。看可以看到这里输出的结果与浏览器Network面板所加载的内容是一样的。
总结
【新一代爬虫利器Python|新一代爬虫利器Python Playwright详解】本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注脚本之家的更多内容!
推荐阅读
- Python爬虫|Python爬虫 --- 1.4 正则表达式(re库)
- 爬虫数据处理HTML转义字符
- 2018-12-05爬虫
- 新一代Python包管理工具
- Python爬虫技术要学到什么程度才可以找到工作()
- python|python 爬虫抓取图片
- 爬虫|若想拿下爬虫大单,怎能不会逆向爬虫,价值过万的逆向爬虫教程限时分享
- 分布式|《Python3网络爬虫开发实战(第二版)》内容介绍
- 【入门】Python网络爬虫与信息提取1
- python|尚硅谷python爬虫(二)-解析方法