尝试编写12306网站查询余票信息的自动化脚本时,碰到日期选择的问题,此处做一下记录:

selenium+python自动化处理时间控件

  最初打算直接定位,但发现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

相关文章:

  • 2022-12-23
  • 2022-01-12
  • 2021-07-31
  • 2021-10-15
  • 2021-07-26
  • 2022-12-23
  • 2021-07-27
  • 2021-11-29
猜你喜欢
  • 2021-07-15
  • 2022-12-23
  • 2021-12-04
  • 2021-11-25
  • 2022-12-23
  • 2021-09-19
相关资源
相似解决方案