Python-webdriver 怎么定位下拉列表中的元素呢

来源:互联网 发布:宝宝日期照相软件 编辑:程序博客网 时间:2024/05/09 12:51

Python-webdriver 怎么定位下拉列表中的元素呢

如果是 select > option*x 结构的话,一般有以下几种做法:

1,定位父元素select(下面语句中的id=aaa),然后通过tag name找到所有option,得到option元素的数组,然后通过数组索引([1])定位,最后click.

driver.find_element_by_id("aaa").find_elements_by_tag_name("option")[1].click();

2 ,  跟第1条差不多思想,不过用option元素的value属性来定位了,下面代码是通过xpath来写的,可以换成 by_css.

driver.find_element_by_xpath("//select[@id='aaa']").find_element_by_xpath("//option[@value='5PM']").click()

3, 用到了Select类, 实例select对象有很多方法:

deselect_all(),全不选。

deselect_by_index(index),不选第 index 项。或者是 index+1项,忘了index从0 还是从1 开始了。

deselect_by_value( value),不选元素value属性为value的项,听着有点拗口,其实value值就是option标签中value的值。

deselect_by_visible_text( text),不选标签innerHTML为text的option

select_by_index( index),同上,选择第 index 项。这个用于 option的text和value不固定的情况

select_by_value( value), 同上,选择。

select_by_visible_text( text),同上,选择。

from selenium.webdriver.support.ui import Select 
 
select = Select(driver.find_element_by_id("aaa")) 
select.deselect_all() 
select.select_by_visible_text("Edam")

基本就这些吧。掌握了这几条,所有的 select 下拉框应该难不住楼主了。网站还有一些用js或者jq模拟出来的下拉框,另作其他处理,在这里就不展开了。

最后 selenium官网 有webdriver的完整文档,包括很多种编程语言版本。可以去看看:selenium官网


原创粉丝点击