小白也可以玩的Python爬虫库,收藏一下
off999 2025-07-10 20:00 37 浏览 0 评论
最近,微软开源了一个项目叫「playwright-python」,作为一个兴起项目,
出现后受到了大家热烈的欢迎,那它到底是什么样的存在呢?今天为你介绍一
下这个传说中的小白神器。
Playwright 是针对 Python 语言的纯自动化工具,它可以通过单个API自动
执行 Chromium,Firefox 和 WebKit 浏览器,连代码都不用写,就能实现
自动化功能。
虽然测试工具 selenium 具有完备的文档,但是其学习成本让一众小白们望而
却步,对比之下 playwright-python 简直是小白们的神器。
Playwright真的适用于Python吗?答案是肯定的,微软对于适用于Python的
Playwright已准备就绪。可能会发生API重大更改。但大概率是这种情况不会
发生,微软还表示仅在他们知道它可以改善您使用新库的体验时,才会可能这
样做。不过微软也提醒尚不支持特定于供应商的API的某些极端情况,例如收集
Chromium跟踪,覆盖率报告等。
1
、
Playwright介绍
Playwright是一个强大的Python库,仅用一个API即可自动执行
Chromium
、
Firefox
、
WebKit等主流浏览器自动化操作,并同时支持以无头
模式、有头模式运行。
Playwright提供的自动化技术是绿色的、功能强大、可靠且快速,支持
Linux
、
Mac以及Windows操作系统。
还有朋友这么夸:这个项目作为针对 Python 语言纯自动化的工具,解放了代
码,实现了自动化功能,我们来看看怎么用它吧。
2
、
Playwright使用
安装
Playwright的安装非常简单,两步解决。
安装playwright库
pip install playwright
安装浏览器驱动文件(安装过程稍微有点慢)
python -m playwright install
复制代码
上面两个pip操作分别安装:
安装Playwright依赖库,需要Python3.7+
安装Chromium、Firefox、WebKit等浏览器的驱动文件
录制
使用Playwright无需写一行代码,我们只需手动操作浏览器,它会录制我们的
操作,然后自动生成代码脚本。
下面就是录制的命令codegen,仅仅一行。
命令行键入 --help 可看到所有选项
python -m playwright codegen
复制代码
codegen的用法可以使用--help查看,如果简单使用就是直接在命令后面加上
url链接,如果有其他需要可以添加options。
python -m playwright codegen --help
Usage: index codegen [options] [url]
open page and generate code for user actions
Options:
-
o, --output <file name> saves the generated script to a file
--
target <language> language to use, one of javascript, python, python-async, csharp (default:
-
h, --help display help for command
Examples:
$
codegen
$
codegen --target=python
$
-
b webkit codegen https://example.com
复制代码
options含义:
-
o:将录制的脚本保存到一个文件
--
target:规定生成脚本的语言,有JS和Python两种,默认为Python
-
b:指定浏览器驱动
比如,我要在baidu.com搜索,用chromium驱动,将结果保存为my.py的
python文件。
python -m playwright codegen --target python -o 'my.py' -b chromium https://www.baidu.com
复制代码
命令行输入后会自动打开浏览器,然后可以看见在浏览器上的一举一动都会被
自动翻译成代码,如下所示。
结束后自动关闭浏览器,保存生成的自动化脚本到py文件。
from playwright import sync_playwright
def run(playwright):
browser = playwright.chromium.launch(headless=False)
context = browser.newContext()
# Open new page
page = context.newPage()
page.goto("https://www.baidu.com/")
page.click("input[name="wd"]")
page.fill("input[name="wd"]", "jingdong")
page.click("text="京东"")
# Click //a[normalize-space(.)='京东JD.COM官网 多快好省 只为品质生活']
with page.expect_navigation():
with page.expect_popup() as popup_info:
page.click("//a[normalize-space(.)='京东JD.COM官网 多快好省 只为品质生活']")
page1 = popup_info.value
# ---------------------
context.close()
browser.close()
with sync_playwright() as playwright:
run(playwright
此外,playwright还提供了同步和异步的API接口,文档如下。
链接:
https://microsoft.github.io/playwright-python/index.html
同步
下面示例代码:依次打开三个浏览器,前往baidu搜索,截图后退出。
from playwright import sync_playwright
with sync_playwright() as p:
for browser
_
type in [p.chromium, p.firefox, p.webkit]:
browser = browser
_
type.launch()
page = browser.newPage()
page.goto('https://baidu.com/')
page.screenshot(path=f'example-{browser_type.name}.png')
browser.close()
复制代码
异步
异步操作可结合asyncio同时进行三个浏览器操作。
import asyncio
from playwright import async_playwright
async 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.newPage()
await page.goto('http://baidu.com/')
await page.screenshot(path=f'example-{browser_type.name}.png')
await browser.close()
asyncio.get_event_loop().run_until_complete(main())
复制代码
移动端
更厉害的是,playwright还可支持移动端的浏览器模拟。下面是官方文档提供
的一段代码,模拟在给定地理位置上手机iphone 11 pro上的Safari浏览器,
首先导航到maps.google.com,然后执行定位并截图。
from playwright import sync_playwright
with sync_playwright() as p:
iphone_11 = p.devices['iPhone 11 Pro']
browser = p.webkit.launch(headless=False)
context = browser.newContext(
**iphone_11,
locale='en-US',
geolocation={ 'longitude': 12.492507, 'latitude': 41.889938 }
,
permissions=['geolocation']
)
page = context.newPage()
page.goto('https://maps.google.com')
page.click('text="Your location"')
page.screenshot(path='colosseum-iphone.png')
browser.close()
复制代码
另外,还可以配合pytest插件一起使用,感兴趣可以自己试一下。
3
、
总结
、
总结
playwright相比已有的自动化测试工具有很多优势,其中有:
支持所有浏览器的
在Chromium,Firefox和WebKit上进行测试。Playwright拥有适用于所
有现代浏览器的完整API覆盖,包括Google Chrome和Microsoft
Edge(带有Chromium),Apple Safari(带有WebKit)和Mozilla
Firefox。
跨平台的WebKit测试。使用Playwright,使用适用于Windows,Linux
和macOS的WebKit构建,测试您的应用程序在Apple Safari中的行为。
在本地和CI上进行测试。
测试手机。使用设备仿真在移动Web浏览器中测试您的自适应Web应用程
序。
无报文头与有报文头。Playwright支持所有浏览器和所有平台的无头(无
浏览器UI)和有头(有浏览器UI)模式。有报文头模式适用于调试,而无报
文头适用于CI / cloud执行。
拥有快速可靠的执行
自动等待APIs。Playwright交互会自动等待直到元素准备就绪。这样可
以提高可靠性并简化测试编写流程。
无超时自动化。Playwright会接收浏览器信号,例如网络请求,页面导
航和页面加载事件,以消除导致睡眠中断的烦恼。
与浏览器上下文保持并行。对于多个并行孤立的浏览器上下文可执行环境
重复使用一个单独的浏览器实例。
弹性元素选择器。Playwright可以依靠面向用户的字符串(例如文本内
容和可访问性标签)来选择元素。这些字符串比紧耦合到DOM结构的选择
器更具弹性。
拥有强大的自动化功能
多个域,页面和框架。Playwright是一种进程外自动化驱动程序,不受
页面内JavaScript执行范围的限制,并且可以自动执行具有多个页面的方
案。
强大的网络控制。Playwright引入上下文范围的网络拦截以便进行终止
或者模拟网络请求。
现代网络功能。Playwright通过插入阴的选择器,地理位置,权
限,Web Worker和其他现代Web API支持Web组件。
涵盖所有场景的能力。支持文件下载和上传,进程外iframe,原生输入事
件,甚至是深色模式。
但它也有局限性
旧版Edge和IE11支持。Playwright不支持旧版Microsoft Edge或
IE11(弃用通知)。支持新的Microsoft Edge(在Chromium上)。
Java语言绑定:Playwright API目前无法在Java或Ruby中使用。这是
暂时的限制,因为Playwright旨在支持任何语言的绑定。
在真实的移动设备上进行测试:Playwright使用桌面浏览器来模拟移动
设备。
虽然有一些局限,但现在playwright 已经更新到了 1.7.0 版本,随着一代代
的更新,系统也会更为完善,作为一款小白神器,为大家省了那么多事情,我
们相信它的未来会越来越好。
相关推荐
- Linux 网络协议栈_linux网络协议栈
-
前言;更多学习资料(包含视频、技术学习路线图谱、文档等)后台私信《资料》免费领取技术点包含了C/C++,Linux,Nginx,ZeroMQ,MySQL,Redis,fastdfs,MongoDB,Z...
- 揭秘 BPF map 前生今世_bpfdm
-
1.前言众所周知,map可用于内核BPF程序和用户应用程序之间实现双向的数据交换,为BPF技术中的重要基础数据结构。在BPF程序中可以通过声明structbpf_map_def...
- 教你简单 提取fmpeg 视频,音频,字幕 方法
-
ffmpeg提取视频,音频,字幕方法(HowtoExtractVideo,Audio,SubtitlefromOriginalVideo?)1.提取视频(ExtractVi...
- Linux内核原理到代码详解《内核视频教程》
-
Linux内核原理-进程入门进程进程不仅仅是一段可执行程序的代码,通常进程还包括其他资源,比如打开的文件,挂起的信号,内核内部的数据结构,处理器状态,内存地址空间,或多个执行线程,存放全局变量的数据段...
- Linux C Socket UDP编程详解及实例分享
-
1、UDP网络编程主要流程UDP协议的程序设计框架,客户端和服务器之间的差别在于服务器必须使用bind()函数来绑定侦听的本地UDP端口,而客户端则可以不进行绑定,直接发送到服务器地址的某个端口地址。...
- libevent源码分析之bufferevent使用详解
-
libevent的bufferevent在event的基础上自己维护了一个buffer,这样的话,就不需要再自己管理一个buffer了。先看看structbufferevent这个结构体struct...
- 一次解决Linux内核内存泄漏实战全过程
-
什么是内存泄漏:程序向系统申请内存,使用完不需要之后,不释放内存还给系统回收,造成申请的内存被浪费.发现系统中内存使用量随着时间的流逝,消耗的越来越多,例如下图所示:接下来的排查思路是:1.监控系统中...
- 彻底搞清楚内存泄漏的原因,如何避免内存泄漏,如何定位内存泄漏
-
作为C/C++开发人员,内存泄漏是最容易遇到的问题之一,这是由C/C++语言的特性引起的。C/C++语言与其他语言不同,需要开发者去申请和释放内存,即需要开发者去管理内存,如果内存使用不当,就容易造成...
- linux网络编程常见API详解_linux网络编程视频教程
-
Linux网络编程API函数初步剖析今天我们来分析一下前几篇博文中提到的网络编程中几个核心的API,探究一下当我们调用每个API时,内核中具体做了哪些准备和初始化工作。1、socket(family...
- Linux下C++访问web—使用libcurl库调用http接口发送解析json数据
-
一、背景这两天由于一些原因研究了研究如何在客户端C++代码中调用web服务端接口,需要访问url,并传入json数据,拿到返回值,并解析。 现在的情形是远程服务端的接口参数和返回类型都是json的字符...
- 平衡感知调节:“系统如人” 视角下的架构设计与业务稳定之道
-
在今天这个到处都是数字化的时代,系统可不是一堆冷冰冰的代码。它就像一个活生生的“数字人”,没了它,业务根本转不起来。总说“技术要为业务服务”,但实际操作起来问题不少:系统怎么才能快速响应业务需求?...
- 谈谈分布式文件系统下的本地缓存_什么是分布式文件存储
-
在分布式文件系统中,为了提高系统的性能,常常会引入不同类型的缓存存储系统(算法优化所带来的的效果可能远远不如缓存带来的优化效果)。在软件中缓存存储系统一般可分为了两类:一、分布式缓存,例如:Memca...
- 进程间通信之信号量semaphore--linux内核剖析
-
什么是信号量信号量的使用主要是用来保护共享资源,使得资源在一个时刻只有一个进程(线程)所拥有。信号量的值为正的时候,说明它空闲。所测试的线程可以锁定而使用它。若为0,说明它被占用,测试的线程要进入睡眠...
- Qt编写推流程序/支持webrtc265/从此不用再转码/打开新世界的大门
-
一、前言在推流领域,尤其是监控行业,现在主流设备基本上都是265格式的视频流,想要在网页上直接显示监控流,之前的方案是,要么转成hls,要么魔改支持265格式的flv,要么265转成264,如果要追求...
- 30 分钟搞定 SpringBoot 视频推拉流!实战避坑指南
-
30分钟搞定SpringBoot视频推拉流!实战避坑指南在音视频开发领域,SpringBoot凭借其快速开发特性,成为很多开发者实现视频推拉流功能的首选框架。但实际开发中,从环境搭建到流处理优...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- 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)