Selenium自动化测试(七)之js处理日期控件

Selenium自动化测试(八)之js处理控件操作

像上面这种使用了日期控件,并且输入框是设置的只读,在做自动化的时候,对于这种我们该如何去做呢?

1、模拟人工点开控件选择日期(不建议使用)
2、跳过该控件,直接输入日期

显然上面两种方式,第一种是相当麻烦不实用的,第二种则是很简便,下面我们来看下如何跳过日期控件:

一、在谷歌浏览器“开发者工具中”的可控制台Console操作处理日期控件

查看元素属性(通过xpath进行的元素定位)
bdata = document.evaluate("//label[contains(text(),'出生日期')]//following::input[1]", document).iterateNext()

删除元素只读属性,使得输入框正常输入内容
bdata.removeAttribute("readonly")

不更改属性值,使用value给输入框赋值
bdata.value="2020-10-23"

直接添加一个value属性
bdata.setAttribute('value','2020-05-01')

二、在Python中处理日期控件

删除元素属性值,添加value值
js = """var bm = document.evaluate(\"//label[contains(text(),'出生日期')]//following::input[1]\", document).iterateNext();
    bm.removeAttribute(\"readonly\");
    bm.value=\"2020-05-01\""""
driver.execute_script(js)
直接添加输入内容
js = """var bm = document.evaluate(\"//label[contains(text(),'出生日期')]//following::input[1]\", document).iterateNext();
    bm.value=\"2020-05-01\""""
driver.execute_script(js)
直接添加一个value属性
js = """var bm = document.evaluate(\"//label[contains(text(),'出生日期')]//following::input[1]\", document).iterateNext();
    bm.setAttribute('value','2020-05-01')"""
driver.execute_script(js)

我的这个元素定位使用的是XPATH(因为没有id/class/name这些简单的,不然我也不会用这么复杂的),当然,你可以选择id/class/name等进行元素定位(如果有的话)。

这种方法不仅适用于日期控件,还可以适用于所有只读的输入框和别的控件。

  • 3
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
Selenium是一个用于自动化Web应用程序测试的工具,它可以模拟用户在浏览器中的操作。在处理日期控件时,Selenium提供了一些方法和技巧来与日期选择器进行交互。 一种常见的日期控件是通过文本框输入日期的方式,你可以使用Selenium的sendKeys()方法来模拟键盘输入。例如,你可以使用以下代码来输入日期"2022-01-01": ```python from selenium import webdriver from selenium.webdriver.common.keys import Keys driver = webdriver.Chrome() driver.get("https://example.com") date_input = driver.find_element_by_id("date-input") date_input.send_keys("2022-01-01") ``` 另一种常见的日期控件是通过下拉菜单或弹出窗口选择日期的方式。对于这种情况,你可以使用Selenium的select类来选择日期。以下是一个示例代码: ```python from selenium import webdriver from selenium.webdriver.support.ui import Select driver = webdriver.Chrome() driver.get("https://example.com") date_select = Select(driver.find_element_by_id("date-select")) date_select.select_by_visible_text("2022-01-01") ``` 如果日期控件是通过JavaScript弹出窗口实现的,你可以使用Selenium的WebDriverWait类来等待弹出窗口的出现,并使用switch_to.window()方法切换到弹出窗口的上下文。以下是一个示例代码: ```python from selenium import webdriver from selenium.webdriver.support.ui import WebDriverWait from selenium.webdriver.support import expected_conditions as EC from selenium.webdriver.common.by import By driver = webdriver.Chrome() driver.get("https://example.com") date_button = driver.find_element_by_id("date-button") date_button.click() # 等待弹出窗口出现 wait = WebDriverWait(driver, 10) wait.until(EC.number_of_windows_to_be(2)) # 切换到弹出窗口的上下文 driver.switch_to.window(driver.window_handles) # 在弹出窗口中选择日期 date_select = driver.find_element_by_id("date-select") date_select.select_by_visible_text("2022-01-01") # 切换回主窗口的上下文 driver.switch_to.window(driver.window_handles) ```
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值