(28)python+playwright自动化测试-日历时间控件-上

1.简介

我们在实际工作中,有可能遇到有些web产品,网页上有一些时间选择,然后支持按照不同时间段范围去筛选数据,例如:我们预定火车票或者预定酒店,需要选择发车日期或者酒店的入住与退房时间。早在之前的12306选出发站就简单的提到过,只不过是一带而过,今天就展开详细介绍一下。网页上日历控件一般,是一个文本输入框,鼠标点击,就会弹出日历界面,可以选择具体日期。这一篇,就来介绍一下日历控件是如何用Playwright实现自动化。

2.JQueryUI网站

2.1被测网址

1.被测网址的地址:

 https://jqueryui.com/resources/demos/checkboxradio/default.html

2.网页如下图:

3.思路一

这里提供两种思路,第一种:比较简单将其看作是文本输入框,直接按照日期格式输入就可以了

3.1代码设计

根据第一种思路进行代码设计如下图所示:

3.2参考代码

# coding=utf-8🔥
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("http://jqueryui.com/resources/demos/datepicker/default.html")
    page.wait_for_timeout(5000)
    page.locator("#datepicker").fill("2023-11-11")
    page.wait_for_timeout(5000)
    context.close()
    browser.close()

with sync_playwright() as playwright:
    run(playwright)

3.3运行代码

1.运行代码,右键Run'Test',查看控制台输出

2.运行代码后电脑端的浏览器的动作。如下图所示:

4.思路二

第二种:通过元素定位,和手工操作一样,将日期一步一步选择点击出来。

4.1代码设计

根据第二种思路进行代码设计如下图所示:

4.2参考代码

# coding=utf-8🔥
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("http://jqueryui.com/resources/demos/datepicker/default.html")
    page.wait_for_timeout(5000)
    # 点击输入框
    page.locator("#datepicker").click()
    # 点击下一个月
    page.locator("//*[@id='ui-datepicker-div']/div/a[@data-handler='next']").click()
    page.wait_for_timeout(1000)
    # xpath定义第二行第六个元素,可能每个月排序不一样,所以不一定点击的就是11日(2023 - 11 - 11)
    page.locator("//*[@id='ui-datepicker-div']/table/tbody/tr[2]/td[7]/a").click()
    page.wait_for_timeout(5000)
    context.close()
    browser.close()

with sync_playwright() as playwright:
    run(playwright)

4.3运行代码

1.运行代码,右键Run'Test',查看控制台输出:

5.小结

日历控件上篇先介绍讲解到这里,后边还有两篇

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

程序员的世界你不懂

你的鼓励将是我创造的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值