首页 > 编程语言 >python+playwright 学习-8.如何在控制台调试定位(Inspect selectors)

python+playwright 学习-8.如何在控制台调试定位(Inspect selectors)

时间:2023-02-22 10:24:28浏览次数:39  
标签:playwright get python Inspect selector Playwright 元素 page

前言

在运行selenium脚本的时候,我们通常习惯用sleep去让页面暂停,打开console 输入 $(selector) 去调试定位页面的元素。
有时候明明页面能找到元素,代码运行却找不到,很是郁闷!
playwright 的page.pause() 断点功能出现,让打开可以愉快的在页面上调试了,我们甚至可以直接使用 playwright.$(selector) 直接支持playwright选择器的方法。

page.pause() 断点

在代码中加入page.pause()进入断点状态

from playwright.sync_api import Playwright, sync_playwright, expect
# 上海悠悠 wx:283340479  
# blog:https://www.cnblogs.com/yoyoketang/

def run(playwright: Playwright) -> None:
    browser = playwright.chromium.launch(headless=False)
    context = browser.new_context()
    page = context.new_page()
    page.goto("http://127.0.0.1:8000/login.html")
    page.get_by_placeholder("请输入用户名").click()
    page.get_by_placeholder("请输入用户名").fill("yoyo")
    page.get_by_placeholder("请输入密码").click()
    page.get_by_placeholder("请输入密码").fill("aa123456")
    page.pause()  # 断点
    page.get_by_role("button", name="立即登录 >").click()

    # ---------------------
    context.close()
    browser.close()


with sync_playwright() as playwright:
    run(playwright)

运行后会弹出 playwright inspector 工具

console 调试定位

我们可以在 用代码打开的浏览器上f12 打开console页面,输入playwright.$(selector) 调试定位

selector 语法可以支持 playwright 的selector 定位的语法。

其它相关操作

  • playwright.$(selector) 使用实际的Playwright查询引擎查询Playwright选择器
  • playwright.$$(selector) 类似于 playwright.$,但是返回全部的匹配元素
  • playwright.inspect(selector) 在元素面板中显示元素(如果相应浏览器的DevTools支持)。
  • playwright.locator(selector) 使用实际的Playwright查询引擎查询Playwright元素
  • playwright.selector(element) 为给定元素生成选择器。

playwright inspector 使用

还可以在playwright inspector 工具上点开启录制按钮,在页面上点点点,就可以生成对应的元素和操作

Pick locator 使用

点击 Pick locator 后在浏览器上选择需要定位的元素,即可生成对应的 locator

标签:playwright,get,python,Inspect,selector,Playwright,元素,page
From: https://www.cnblogs.com/yoyoketang/p/17143389.html

相关文章

  • python 删除大于超过一定时间文件
    importosfromdatetimeimportdatetime,timedeltapath="."if__name__=='__main__':forroot,firs,filesinos.walk(path):forfileinfiles......
  • 【python】python基本语法
    字符串字符串是否包含子字符串两种方法:[find()][in]/[notin]//方法一ifstring1.find(string2):print("foundstring2instring1")//方法二ifstring2in......
  • python+playwright 学习-7.录制生成脚本
    前言playwright可以支持自动录制生成脚本,也就是说只需要在页面上点点点,就可以自动生成对应的脚本了。启动运行Playwright具有开箱即用的生成测试的能力,是快速开始测试......
  • Python中函数参数是如何传递的?
    Python函数相比对于多数程序员来说不陌生吧,那么Python函数中的参数是如何传递的呢?首先我将会以代码图文的形式给大家展现以下,看看是不是和您所认知的Python函数一样的结果?......
  • 一文了解Python协程本质
    关于Python协程我觉得当你学到一定程度的时候一定要懂,比如你在对代码进行优化或者提升速度时,就不得不使用异步编程,加上现在有很多的优秀第三方库都可以实现异步编程,从而让......
  • 计算程序总行数的Python代码
    最近需要统计一下项目中代码的总行数,写了一个Python小程序,不得不说Python是多么的简洁,如果用Java写至少是现在代码的2倍。importospath="/Users/rony/workspace/ecomm......
  • python的GIL全局解释器锁
    globalinterpreterlock--全局解释器锁CPython 解释器所采用的一种机制,它确保同一时刻只有一个线程在执行Python bytecode。此机制通过设置对象模型(包括 dict 等......
  • python一记
    作者:荷兰人吉多.范罗苏姆python:蟒蛇特点:跨平台/解释型/交互式/弱类型/面向对象新建myPython.py并:print('hello,world')print可以输出的内容:数字,字符,布尔表达式,运......
  • Python报错: KeyError: 'HOME'——mac中的os.environ['HOME'],windows写法:os.environ['H
    windows写法——os.environ['HOMEPATH']对应的mac写法——os.environ['HOME']windows:os.environ['HOME']会报错—— KeyError:'HOME'  改成os.environ['HOMEPATH'......
  • Python中的命名规范
    变量命名准则您应当尽量使自己的变量命名含义清晰,不要使用混乱的字母、数字、表情等意义不明的字符来命名变量一般来说,您不应当使自己的风格频发变换——如果可能,请将整......