当前位置: 首页 > article >正文

python+playwright自动化测试(四):元素操作(键盘鼠标事件)、文件上传

目录

鼠标事件

悬停

移动

按键

点击

滚轮操作

拖拽

键盘事件

输入文本内容

type输入内容

fill输入内容

按键操作press

文件上传

下拉选/单选框/复选框

滚动条操作


鼠标事件

悬停

page.get_by_text('设置',exact=True).nth(1).hover()

移动

page.mouse.move(x=33, y=50)

按键

# 点击操作可设置button参数,选择点击键["left", "middle", "right"]
page.mouse.click(x=100, y=200)
page.mouse.dblclick(x=100, y=200)
page.mouse.up()
page.mouse.down()

点击

点击支持选择不同点击键["left", "middle", "right"]

    page.click('#su')  # 单击,默认点击左键

    page.locator('xpath=//a[text()="百度首页"]').dispatch_event('click')  # 此方法支持键盘等事件,参数为click时同click()

    page.locator('xpath=//a[text()="设置"]').click(button='right')  # 右击
    
    page.locator('xpath=//a[text()="百度首页"]').click(position={'x': 10, 'y': 20})  # 点击元素的某个点

    # 键盘+鼠标点击,键盘键支持的类型(Alt|Control|ControlOrMeta|Meta|Shift)
    page.locator('xpath=//a[text()="百度首页"]').click(modifiers=["Shift"])  # 模拟按下Shift同时点击元素

    page.locator('#su').dblclick()  # 双击

滚轮操作

    page.mouse.wheel(delta_x=100, delta_y=0)  # 水平向右
    page.mouse.wheel(delta_x=-100, delta_y=0)  # 水平向左
    page.mouse.wheel(delta_x=0, delta_y=500)  # 垂直向下
    page.mouse.wheel(delta_x=0, delta_y=-500)  # 垂直向上

    for _ in range(100):
        page.mouse.wheel(delta_x=0, delta_y=10)
        sleep(.1)

拖拽

拖拽的分步式为先鼠标悬停到要拖拽的元素上,然后按下鼠标不放,再将鼠标移动到目标为止松开鼠标。

    page.locator('xpath=//a[text()="百度首页"]').hover()
    page.mouse.down()
    page.locator('#kw').hover()
    page.mouse.up()

合并写法

    page.locator('xpath=//a[text()="百度首页"]').drag_to(page.locator('#kw'))

键盘事件

    page.keyboard.insert_text('测试一下')  # 键盘输入内容,这个操作只触发‘input’事件,不发出‘keydown’, ‘keyup’或‘keypress’事件。
    for _ in range(5):
        page.keyboard.press('Control+A')
        page.keyboard.press('Control+C')
        page.keyboard.press('Control+V')
    page.keyboard.down('Control')  # 按下
    page.keyboard.up('Control')  # 抬起

输入文本内容

type和fill支持input、textarea、contenteditable标签元素的内容输入。但输入结果有所不同,type()输入内容不会清除后输入,会在原来内容的基础上追加。fill()会先清空内容后再输入,可以看成clean和type的组合。通过循环输入可看出差异

type输入内容
    # 清空内容
    page.locator('#kw').clear() 

    for _ in range(5):
        page.locator('#kw').type(text='测试')
        sleep(.5)
fill输入内容
    for _ in range(5):
        # page.fill('#kw', '自动化')
        page.locator('#kw').fill('测试')

按键操作press

支持键盘按键,可执行的按键有Backquote, Minus, Equal, Backslash, Backspace, Tab, Delete, Escape,ArrowDown, End, Enter, Home, Insert, PageDown, PageUp, ArrowRight,ArrowUp, F1 - F12, Digit0 - Digit9, KeyA - KeyZ, etc。同时支持单个字符的输入,如输入特殊符号,如¥,&等。

Control(即Ctrl键)、方向键ArrowLeft(小键盘左边的向左的箭头键,可根据实际需要换成对应的方向键)

    page.locator('#kw').press("Control+ArrowLeft")
    page.locator('#kw').press("Control+ArrowRight")
    page.locator('#kw').press("&")  # 输入&符号
    page.locator('#kw').press("Shift+A")  # 控制输入大小写

文件上传

支持上传单个或多个文件上传多个文件时,使用列表传入。

    file_name = [r'D:\儿童音频诗词歌曲\22  三字经+弟子规+百家姓(全集)跟读\11 《三字经》11.mp3',r'D:\儿童音频诗词歌曲\22  三字经+弟子规+百家姓(全集)跟读\10 《三字经》10.mp3']
    page.locator('xpath=//input[@name="file"][@multiple="multiple"]').nth(0).set_input_files(file_name)

下拉选/单选框/复选框

select_option()支持在 < select > 元素中选择一个或多个选项。# 支持value和label的参数选择(参数值可以是单个字符串或多个值的列表),支持通过下标index选择(参数值可以是单个int值或多个int值的列表),根据多选和单选决定。

page.locator('xpath=//select[@name="sutext"]').select_option('启用')

对于input中具有checkbox属性的元素可使用check或set_checked选择值。set_checked是选中或取消选择复选框或单选按钮最简单的方法。

page.get_by_label('XXX').check()  # 选中
page.get_by_label('XXX').uncheck()  # 取消选中
page.get_by_label('XXX').is_checked()  # 元素是否选择状态,返回布尔值
page.locator('[value="姓名"]').set_checked(checked=True)  # set_checked设置选中状态
page.set_checked('[value="姓名"]', checked=True)

滚动条操作

滚动操作有三种方式:通过上面的鼠标滚轮操作、通过scroll_into_view_if_needed方法操作、通过执行JavaScript语句操作。

通过滚轮和JavaScript语句操作可通过先获取页面高度再循环操作。

    height = page.query_selector('body').evaluate("document.body.scrollHeight")  # 获取页面高度
    for h in range(0, height, 100):  # 每100个像素滚动一次
        # page.evaluate_handle(f'window.scrollTo(0,{h});')
        page.evaluate(f'window.scrollTo(0,{h});')
        page.wait_for_timeout(500)

滚动到指定元素出现

方法1:

page.locator('xpath=//input[@name="file"][@multiple="multiple"]').last.scroll_into_view_if_needed()  # 滚动到指定元素为止

方法2:

expression = '''
        const element = document.querySelector("#su");
        if (element) {
  
  {
            element.scrollIntoView();
        }}'''
page.evaluate(expression)

http://www.kler.cn/a/516501.html

相关文章:

  • Ubuntu 20.04 x64下 编译安装ffmpeg
  • go-zero框架基本配置和错误码封装
  • vim在命令模式下的查找功能
  • 逐笔成交逐笔委托Level2高频数据下载和分析:20250122
  • rocketmq基本架构
  • 深入探讨视图更新:提升数据库灵活性的关键技术
  • 把markdown转换为pdf的方法
  • AI引领工业制造智能化革命:机器视觉与时序数据预测的双重驱动
  • 工业“MCU+AI”
  • 企业智能文档助手方案
  • SpringCloudAlibaba 服务保护 Sentinel 项目集成实践
  • strdup 函数
  • 字符串重新排列
  • C22.【C++ Cont】位运算总结(1)(例题五种解法!含汇编解法)
  • 【运维】什么是Prometheus普罗米修斯?组件式开发
  • 放弃使用Dockerfiles 平替 docker init
  • 【Block总结】FreqFusion特征融合模块,适用于分割、检测任务|即插即用
  • Kafka面试题----Kafka消息是采用Pull模式,还是Push模式
  • Python 在Word中添加、或删除超链接
  • 机器人奇点:从宇树科技看2025具身智能发展
  • 如何将pdf文件中的指定页提取出来,另存为新的pdf文件
  • 【C】链表算法题4 -- 合并两个有序链表
  • Spring MVC:深入理解与春招面试要点
  • Jenkins邮件通知的详细配置含邮件通知模板!
  • MyBatis-Plus的插件
  • 如何查找pom文件未使用的依赖