selenium之元素定位的方法(一)

WebDriver 对象有多种方法用于在页面中寻找元素。他们被分成find_element_*和find_elements_*方法。
find_element_*方法返回一个WebElement对象,代表页面中匹配查询的第一个元素。find_elements_*方法
返回WebElement_*对象的列表,包含页面中所有匹配的元素。

使用CSS类name的元素
driver.find_element_by_class_name(name)
driver.find_elements_by_class_name(name)
匹配CSS selector 的元素
driver.find_element_by_css_selector(selector)
driver.find_elements_by_css_selector(selector)
匹配id属性值的元素
driver.find_element_by_id(id)
driver.find_elements_by_id(id)
完全匹配提供的text的<a>元素
driver.find_element_by_link_text(text)
driver.find_elements_by_link_text(text)
包含提供的text的<a>元素
driver.find_element_by_partial_link_text(text)
driver.find_element_by_partial_link_text(text)
匹配name属性值的元素
driver.find_element_by_name(name)
driver.find_elements_by_name(name)
匹配标签name的元素(大小写无关,<a>元素匹配"a"和"A"
driver.find_element_by_tag_name(name)
driver.find_elements_by_tag_name(name)

除了*_by_tag_name()方法,所有方法的参数都是区分大小写的。如果页面上没有元素匹配该方法的要查找的元素,
selenium模块就会抛出NoSuchElement异常。如果你不希望这个异常让程序崩溃,就在代码中添加try和except语句。
一旦有了WebElement对象,就可以读取如下表中的属性,或调用其中的方法,了解他的更多功能。

tag_name 标签名,例如“a”表示<a>元素
get_attribute(name) 该元素name属性的值
text 该元素的文本,例如<span>hello</span>中的“hello”
clear() 对于文本字段或文本区域元素,清楚其中输入的文本
is_display() 如果该元素可见,返回True,否则返回False
is_enable() 对于输入元素,如果该元素启用,返回True,否则返回False
is_selected() 对于复选框或单选框元素,如果该元素被选中,选择True,否则返回False
location 一个字典,包含键“x”和“y”,表示该元素在页面上的位置


from selenium import webdriver

url = "http://www.baidu.com"
driver = webdriver.Firefox()
driver.get(url)
try:
ele = driver.find_element_by_name("kw")
print("Found<%s> element with that class name!"%(ele.text))
except:
print("Was not able to find an element with that name")

这里我们打开FireFox,让它指向一个URL。在这个页面上,我们试图找到带有元素名字的“kw”的元素。如果找到
这样的元素,我们就用text属性将文本值打印出来,如果没有这样的元素,就打印不同的信息。
posted @ 2021-02-12 15:37  逆风前进的狼  阅读(163)  评论(0编辑  收藏  举报