尝试编写12306网站查询余票信息的自动化脚本时,碰到日期选择的问题,此处做一下记录:
最初打算直接定位,但发现2017-09-30这一天实在没什么特点,虽然也可以根据父元素的特征属性层层定位,然后选择其下的第多少个child元素,但是感觉会有问题,过一天之后,这个child元素就不是30号了,与初衷不符,于是网上查找了解决办法,看到有说去掉这里时间框的readonly属性,直接用输入的办法是用send_keys解决,所有碰到的时间选择,都可以通过这种方式解决,深以为然,然后试了一下,果然可以,这里把方法记下来:
方法一:原生js,移除readonly属性
js = "document.getElementById('train_date').removeAttribute('readonly')"
方法二:jQuery,移除readonly属性
js = "$('input[id=train_date]').removeAttr('readonly')"
方法三:jQuery,设置属性为false
js = "$('input[id=train_date]').attr('readonly',false)"
方法四:jQuery,设置属性为空
js = "$('input[id=train_date]').attr('readonly',’ ‘)"
然后,
driver.execute_script(js)
driver.find_element_by_id('train_date').clear()
driver.find_element_by_id('train_date').send_keys('2017-09-30')
问题解决!
注:此文章内容参考huilan_same的csdn博客,但笔者有实际尝试过,确实可行,感谢huilan_same提供的方法。
原文地址:http://blog.csdn.net/huilan_same/article/details/52385401