一 方法
selenium为定位元素提供了较多方法,大致分为单元素定位和多元素定位.
# 查找单个元素:
find_element_by_id
find_element_by_name
find_element_by_xpath
find_element_by_link_text
find_element_by_partial_link_text
find_element_by_tag_name
find_element_by_class_name
find_element_by_css_selector
# 查找多个元素
find_elements_by_name find_elements_by_xpath find_elements_by_link_text find_elements_by_partial_link_text find_elements_by_tag_name find_elements_by_class_name find_elements_by_css_selector
# 两个私有方法
find_element
find_elements
二 用法
2.1 find_element和find_elements用法
from selenium.webdriver.common.by import By driver.find_element(By.XPATH, '//button[text()="Some text"]') driver.find_elements(By.XPATH, '//button')
按各种分类的属性如下:
XPATH = "xpath" LINK_TEXT = "link text" PARTIAL_LINK_TEXT = "partial link text" NAME = "name" TAG_NAME = "tag name" CLASS_NAME = "class name" CSS_SELECTOR = "css selector"
2.2 按IP定位
login_form = driver.find_element_by_id('loginForm')
使用此策略,将返回id属性值与位置匹配的第一个元素。如果没有元素具有匹配的id属性,NoSuchElementException
则将引发a。
2.3 按name定位
username = driver.find_element_by_name('username') password = driver.find_element_by_name('password')
使用此策略,将返回name属性值与位置匹配的第一个元素。如果没有元素具有匹配的name属性,NoSuchElementException
则将引发a。
2.4 通过XPath定位
使用XPath的主要原因之一是,当您没有想要查找的元素的合适的id或name属性时。您可以使用XPath以绝对术语(不建议使用)定位元素,也可以相对于具有id或name属性的元素定位。XPath定位器还可用于通过id和name以外的属性指定元素。
绝对XPath包含来自根(html)的所有元素的位置,因此,仅对应用程序进行一点点调整就可能导致失败。通过找到具有id或name属性的附近元素(最好是父元素),您可以根据关系找到目标元素。这种更改的可能性要小得多,并且可以使您的测试更可靠。
<html> <body> <form id="loginForm"> <input name="username" type="text" /> <input name="password" type="password" /> <input name="continue" type="submit" value="Login" /> <input name="continue" type="button" value="Clear" /> </form> </body> <html>
如下定位:
# 绝对路径(如果仅对HTML进行少许更改,则会中断) login_form = driver.find_element_by_xpath("/html/body/form[1]") # HTML中的第一个表单元素 login_form = driver.find_element_by_xpath("//form[1]") # 具有名为id的属性和值为loginForm的表单元素 login_form = driver.find_element_by_xpath("//form[@id='loginForm']")
2.4.1 绝对路径(如果仅对HTML进行少许更改,则会中断)
login_form = driver.find_element_by_xpath("/html/body/form[1]")
2.4.2 元素及其属性定位
查找具体的元素,必须在前面输入标准开头//,表示从当前节点寻找所有的后代元素
//div/* div下面的所有的元素 //div//p 先在整个文档里查找div,再在div里查找p节点(只要在内部,不限定是否紧跟) ;等价于 css_selector里的('div p') //div/p p是div的直接子节点; 等价于 css_selector里的('div > p') //*[@style] 查找所有包含style的所有元素,所有的属性要加@; 等价于 css_selector里的('*[style]') //p[@spec='len'] 必须要加引号;等价于 css_selector里的("p[spec='len']") //p[@id='kw'] xpath中对于id,class与其他元素一视同仁,没有其他的方法
2.4.3 选择节点位置
//div/p[2] 选择div下的第二个p节点 ;等价于css_selector里的div>p:nth-of-type(2) 符合p类型的第二个节点 //div/*[2] 选择div下第二个元素 //div/p[position()=2] position()=2 指定第二个位置; 等价于上面的 //div/p[2] position()>=2 位置大于等于2 position()<2 位置小于2 position()!=2 位置不等于2 //div/p[last()] 选择div下的倒数第一个p节点; last()倒数第一个 //div/p[last()-1] 选择div下的倒数第二个p节点; //div/p[position()=last()] 倒数第一个 //div/p[position()=last()-1] 倒数第二个 //div/p[position()>=last()-2]倒数第一个,第二个,第三个
2.4.4 组合定位
//p | //button 选择所有的p和button,等价于css_selector里的 p, button //input[@id='kw' and @class='su'] 选择id=kw 并且 class=su的input元素
2.4.5 兄弟节点
相邻后面的兄弟节点的选择:following-sibling:: 两个冒号 //div/following-sibling::p 选择div里相邻的p节点 相邻前面的兄弟节点的选择:preceding-sibling:: 此方法在css_selector中没有 //div/preceding-sibling::p[2] 选择div里前面相邻的第二个节点,不加[2]选择的是前面的所有的p节点
2.4.6 父节点
//p[@spec='len']/.. 选择p节点的上层节点 此方法在css_selector中没有 //p[@spec='len']/../.. 上层节点的上层节点
2.5 通过链接文本找超链接
<html> <body> <p>Are you sure you want to do this?</p> <a href="continue.html">Continue</a> <a href="cancel.html">Cancel</a> </body> <html>
continue_link = driver.find_element_by_link_text('Continue') continue_link = driver.find_element_by_partial_link_text('Conti')
使用此策略,将返回链接文本值与位置匹配的第一个元素。如果没有元素具有匹配的链接文本属性,NoSuchElementException
则将引发a。
2.6 通过标签名称定位
<html> <body> <h1>Welcome</h1> <p>Site content goes here.</p> </body> <html>
heading1 = driver.find_element_by_tag_name('h1')
使用此策略,将返回具有给定标签名称的第一个元素。如果没有元素具有匹配的标签名称,NoSuchElementException
则将引发a。
2.7 通过class定位
<body> <p class="content">Site content goes here.</p> </body> <html>
content = driver.find_element_by_class_name('content')
使用此策略,将返回具有匹配类属性名称的第一个元素。如果没有元素具有匹配的类属性名称,NoSuchElementException
则将引发a。
2.8 通过CSS选择器定位
<html> <body> <p class="content">Site content goes here.</p> </body> <html>
content = driver.find_element_by_css_selector('p.content')
使用此策略,将返回具有匹配CSS选择器的第一个元素。如果没有元素具有匹配的CSS选择器,NoSuchElementException
则将引发a。
结束!