- 问题:
采用python+selenium 做管理后台自动化测试,遇到日期选择框不能直接录入日期,只能手动选择,为了方便后续测试,研究下如何直接输入日期+时间 - 解决方案:
参照:
#类型为不可输入的,且属性为readonly,先用js去掉readonly属性,然后输入文本内容
from selenium import webdriver
import time
driver = webdriver.Ie()
driver.get('https://kyfw.12306.cn/otn/index/init')
driver.implicitly_wait(4)
js = 'document.getElementById("train_date").removeAttribute("readonly");' #js去掉readonly属性
driver.execute_script(js)
js_value = 'document.getElementById("train_date").value="2018-08-22"' #js添加时间
driver.execute_script(js_value)
time.sleep(2)
driver.quit()
- 关键点:
由于对象没有使用ID属性,所以完全使用上述方法无效,需要修改下js获取元素方法
https://www.jb51.net/article/122126.htm
querySelector():
接收一个参数:一个包含一个或多个CSS 选择器的字符串(多个选择器以逗号分隔),返回匹配指定CSS选择器的第一个元素节点(无法选中CSS伪元素),没有发现匹配的节点则返回null。
代码修改如下:
js = 'document.querySelector(".el-date-editor--date > input:nth-child(2)").removeAttribute("readonly");' #js去掉readonly属性
self.dr.execute_script(js)
js_value = 'document.querySelector(".el-date-editor--date > input:nth-child(2)").value="2018-10-22"' #js添加时间
self.dr.execute_script(js_value)
print('ok')
或者使用send_keys输入时间:
self.dr.find_element_by_css_selector('.el-date-editor--date > input:nth-child(2)').send_keys('2018-11-22')
问题解决。
总结:
由于日期选择框对象没有使用ID对象,所以把document.getElementById 改成 document.querySelector 可以识别css对象的方法
然后使用Firefox获取到css选择器(.el-date-editor–date > input:nth-child(2))替换train_date 、