《最新出炉》系列入门篇-Python+Playwright自动化测试-45-鼠标操作-下篇

python,playwright · 浏览次数 : 0

小编点评

**鼠标操作语法** * `page.mouse.move(x: float, y: float, *, steps: typing.Optional[int] = None)`:移动鼠标到指定的坐标(x,y)。 * `page.mouse.down()`:按下鼠标。 * `page.mouse.up()`:释放鼠标。 * `page.mouse.wheel(delta_x, delta_y)`:向鼠标滚动。 **示例** ```python # 使用 ` page.mouse` 画一个100x100的正方形。 page.mouse.move(0, 0) # 按下鼠标 page.mouse.down() # 鼠标纵坐标向下移动100像素 page.mouse.move(0, 100) # 鼠标横坐标向右移动100像素 page.mouse.move(100, 100) # 鼠标纵坐标向上移动100像素 page.mouse.move(100, 0) # 鼠标纵坐标向左移动100像素 page.mouse.move(0, 0) # 释放鼠标 page.mouse.up() ``` **运行轨迹** [鼠标移动到(0,0)坐标] --> [鼠标按下down] --> [鼠标纵坐标向下移动100像素] --> [鼠标横坐标向右移动100像素] --> [鼠标纵坐标向上移动100像素] --> [鼠标纵坐标向左移动100像素] --> [鼠标释放] **组合拳** * `page.mouse.move()`:鼠标移动。 * `page.mouse.down()`:鼠标按下。 * `page.mouse.up()`:鼠标释放。 **滚轮** * `page.mouse.wheel(delta_x, delta_y)`:向鼠标滚动。 **牛刀小试** * 测试网址:`cps-check.com/cn/mouse-buttons-test` * 代码设计: * 导入 `playwright.sync_api` 模块。 * 定义 `run()` 函数,接收 `Playwright` 对象。 * 启动 ChromeDriver。 * 创建新的页面。 * 打开测试网址。 * 移动鼠标到测试框内。 * 按下鼠标左键。 * 释放鼠标。 * 等待页面加载。

正文

1.简介

鼠标为我们使用电脑提供了很多方便,我们看到的东西就可以将鼠标移动过去进行点击就可以打开或者访问内容,当页面内容过长时,我们也可以使用鼠标滚轮来实现对整个页面内容的查看,其实playwright也有鼠标操作的方法。上一篇文章中已经讲解过鼠标的部分操作了,今天宏哥在这里将剩下的其他操作进行一个详细地介绍和讲解。

2.鼠标操作语法

鼠标操作介绍官方API的文档地址:https://playwright.dev/docs/api/class-mouse

Mouse鼠标操作是基于page对象去调用。常用的鼠标操作有单击,双击,滚轮,按住,移动,释放。

2.1官方示例

1.使用` page.mouse` 画 一个100x100的正方形。语法如下:

# Using ‘page.mouse’ to trace a 100x100 square.
# 鼠标移动到(0,0)坐标
await page.mouse.move(0, 0);
# 按下鼠标
await page.mouse.down();
# 鼠标纵坐标向下移动100像素
await page.mouse.move(0, 100);
# 鼠标横坐标向右移动100像素
await page.mouse.move(100, 100);
# 鼠标纵坐标向上移动100像素
await page.mouse.move(100, 0);
# 鼠标纵坐标向左移动100像素
await page.mouse.move(0, 0);
# 释放鼠标
await page.mouse.up();

2.鼠标运行轨迹,如下图所示:

3.组合拳

mouse.move()、mouse.down()、mouse.up()三个一般都是组合出现在代码里的一套组合拳。

3.1down模拟鼠标按下

down模拟鼠标按下,主要是通过调度一个mousedown事件。

3.1.1参数详解

「参数」

参数

类型

释义

button

list["left", "middle", "right"]

左中右可选

click_count

int

默认值为1,含义参考:https://developer.mozilla.org/en-US/docs/Web/API/UIEvent/detail

3.1.2使用方法
mouse.down()
mouse.down(**kwargs)

3.2.move模拟鼠标移动

move模拟鼠标移动,主要是通过调度一个mousemove事件。语法如下:

def move(self, x: float, y: float, *, steps: typing.Optional[int] = None) -> None:
        """Mouse.move

        Dispatches a `mousemove` event.

        Parameters
        ----------
        x : float
        y : float
        steps : Union[int, None]
            Defaults to 1. Sends intermediate `mousemove` events.
        """
3.2.1参数详解

参数

类型

释义

x

float

x坐标

y

float

y坐标

steps

 
3.2.2使用方法
mouse.move(x, y)
mouse.move(x, y, **kwargs)

3.3up模拟鼠标释放

up模拟鼠标释放,主要是通过调度一个mouseup事件。

3.2.1参数详解

参数

类型

释义

button

list["left", "middle", "right"]

左中右可选

click_count

int

默认值为1,含义参考:https://developer.mozilla.org/en-US/docs/Web/API/UIEvent/detail

3.2.2使用方法
mouse.up()
mouse.up(**kwargs)

4.wheel模拟鼠标滚动

wheel模拟鼠标滚动,是通过调度一个wheel事件。(滚轮事件如果不处理可能会导致滚动,该方法不会等待滚动结束才返回。)

4.1参数详解

参数

类型

释义

delta_x

float

要水平滚动的像素

delta_y

float

要垂直滚动的像素

4.2使用方法

mouse.wheel(delta_x, delta_y)

5.牛刀小试

5.1测试网址

https://cps-check.com/cn/mouse-buttons-test

  • 未按鼠标时,不会显示其他颜色
  • 长按鼠标左键时,页面会显示红色的左键
  • 按下鼠标左键松开时,页面会显示粉红色的左键

5.1代码设计

5.2参考代码

# coding=utf-8🔥

# 1.先设置编码,utf-8可支持中英文,如上,一般放在第一行

# 2.注释:包括记录创建时间,创建人,项目名称。
'''
Created on 2023-12-12
@author: 北京-宏哥
公众号:北京宏哥
Project: 《最新出炉》系列入门篇-Python+Playwright自动化测试-44-鼠标操作-上篇
'''

# 3.导入模块
from playwright.sync_api import Playwright, sync_playwright, expect

def run(playwright: Playwright) -> None:

    browser = playwright.chromium.launch(headless=False)
    context = browser.new_context()
    page = context.new_page()
    page.goto("https://cps-check.com/cn/mouse-buttons-test")
    page.wait_for_timeout(1000)
    #将鼠标移到测试框内
    page.mouse.move(650,300)
    #按下左键
    page.mouse.down()
    page.wait_for_timeout(20000)
    #释放
    page.mouse.up()
    page.wait_for_timeout(2000)
    #page.pause()
    context.close()
    browser.close()

with sync_playwright() as playwright:
    run(playwright)

5.3运行代码

1.运行代码,右键Run'Test',控制台输出,如下图所示:

2.运行代码后电脑端的浏览器的动作(图片中的鼠标左键先显示红色然后显示粉色)。如下图所示:

6.wheel模拟鼠标滚动

wheel模拟鼠标滚动,就是通过调度一个wheel事件。(滚轮事件如果不处理可能会导致滚动,该方法不会等待滚动结束才返回。)

6.1参数详解

参数

类型

释义

delta_x

float

要水平滚动的像素

delta_y

float

要垂直滚动的像素

6.2使用方法

mouse.wheel(delta_x, delta_y)

7.小结

 到此,鼠标的一些常用的操作基本上都已经讲解和分享完成,当然了可能还有其他操作,这个等我遇到的时候,再具体问题具体分析。好了,今天时间也不早了,宏哥就讲解和分享到这里,感谢您耐心的阅读,希望对您有所帮助。

与《最新出炉》系列入门篇-Python+Playwright自动化测试-45-鼠标操作-下篇相似的内容:

《最新出炉》系列入门篇-Python+Playwright自动化测试-45-鼠标操作-下篇

1.简介 鼠标为我们使用电脑提供了很多方便,我们看到的东西就可以将鼠标移动过去进行点击就可以打开或者访问内容,当页面内容过长时,我们也可以使用鼠标滚轮来实现对整个页面内容的查看,其实playwright也有鼠标操作的方法。上一篇文章中已经讲解过鼠标的部分操作了,今天宏哥在这里将剩下的其他操作进行一个

《最新出炉》系列入门篇-Python+Playwright自动化测试-52- 字符串操作 - 下篇

1.简介 在日常的自动化测试工作中进行断言的时候,我们可能经常遇到的场景。从一个字符串中找出一组数字或者其中的某些关键字,而不是将这一串字符串作为结果进行断言。这个时候就需要我们对字符串进行操作,宏哥这里介绍两种方法:正则和字符串切片函数split()。 2.测试场景 宏哥在这里说一下,自己的胡诌的

《最新出炉》系列入门篇-Python+Playwright自动化测试-51- 字符串操作 - 上篇

1.简介 在日常的自动化测试工作中进行断言的时候,我们可能经常遇到的场景。从一个字符串中找出一组数字或者其中的某些关键字,而不是将这一串字符串作为结果进行断言。这个时候就需要我们对字符串进行操作,宏哥这里介绍两种方法:正则和字符串切片函数split()。 2.测试场景 宏哥在这里说一下,自己的胡诌的

《最新出炉》系列入门篇-Python+Playwright自动化测试-50-滚动条操作

1.简介 有些页面的内容不是打开页面时直接加载的,需要我们滚动页面,直到页面的位置显示在屏幕上时,才会去请求服务器,加载相关的内容,这就是我们常说的懒加载。还有就是在日常工作和学习中,经常会遇到我们的页面内容较多,一个屏幕范围无法完整展示内容,我们就需要滚动滚动条去到我们想要的地方,所以有时候我们就

《最新出炉》系列入门篇-Python+Playwright自动化测试-49-Route类拦截修改请求-下篇

1.简介 在日常工作和学习中,自动化测试的时候:在加载页面时,可能页面出现很多不是很重要或者不是我们所关注的,这个时候我们就可以选择不加载这些内容,以提高页面加载速度,节省资源。例如:可能页面上图片比较多,而我们又不关心图片内容。那么,在加载页面时,可以选择不加载图片,以提高页面加载速度。这里我们主

《最新出炉》系列入门篇-Python+Playwright自动化测试-48-Route类拦截修改请求-上篇

1.简介 在日常工作和学习中,自动化测试的时候:在加载页面时,可能页面出现很多不是很重要或者不是我们所关注的,这个时候我们就可以选择不加载这些内容,以提高页面加载速度,节省资源。例如:可能页面上图片比较多,而我们又不关心图片内容。那么,在加载页面时,可以选择不加载图片,以提高页面加载速度。这里我们主

《最新出炉》系列入门篇-Python+Playwright自动化测试-47-自动滚动到元素出现的位置

1.简介 在我们日常工作中或者生活中,经常会遇到我们的页面内容较多,一个屏幕范围无法完整展示内容,我们就需要滚动滚动条去到我们想要的地方,如下图页面,我们虽然在豆瓣首页,但是内容并不完整,如果我们想要直接点击电影模块中的选电影按钮,是需要往下滑动的。当页面超过屏幕的高度时候,需要滚动到元素出现的位置

《最新出炉》系列入门篇-Python+Playwright自动化测试-46-鼠标滚轮操作

1.简介 有些网站为了节省流量和资源,提高加载效率,采用的是动态加载(懒加载)的,也就是当拖动页面右侧滚动条后会自动加载网页下面的内容,不拖动就不会加载的或者通过鼠标滚轮操作。 2.wheel模拟鼠标滚动 wheel模拟鼠标滚动,就是通过调度一个wheel事件。(滚轮事件如果不处理可能会导致滚动,该

《最新出炉》系列入门篇-Python+Playwright自动化测试-44-鼠标操作-上篇

1.简介 前边文章中已经讲解过鼠标的拖拽操作,今天宏哥在这里对其的其他操作进行一个详细地介绍和讲解,然后对其中的一些比较常见的、重要的操作单独拿出来进行详细的介绍和讲解。 2.鼠标操作语法 鼠标操作介绍官方API的文档地址:https://playwright.dev/docs/api/class-

《最新出炉》系列入门篇-Python+Playwright自动化测试-43-分页测试

1.简介 分页测试,这种一般都是公共的方法系统中都写好了,这种一般出现是数据展示比较多的时候,会采取分页的方法,而且比较固定,一般是没有问题的,因此它非常适合自动化测试,但是如何使用playwright来进行分页自动化测试了,宏哥今天就讲解和分享一下。 2.测试场景 对分页来说,我们最感兴趣的和测试