selenium定位中高级语法
一、xpath定位中starts-with、contains和text()的用法
starts-with :匹配一个属性开始位置的关键字来定位元素
contains :匹配一个属性值中包含的字符串来定位元素
text() 匹配的是显示文本信息,文本为指定内容的元素所在位置
案例:
//input[starts-with(@name,'666')] 查找name属性中【开始】位置包含'666'关键字的页面元素
//input[contains(@name,'66')] 查找name属性中包含66关键字的页面元素
<a href="http://www.baidu.com">百度搜索</a>
xpath写法为 //a[text()='百度搜索'] 或者 //a[contains(text(),"百度搜索")]
注:如果需要变量查询则可以采用%s或者’’.format()实现://a[contains(text(),"%s")] %(这是变量名) ///a[contains(text(),’{}’)].format(变量)
二、XPATH的层级定位
1、父级定位子级
首先定位到父级(定位方法不限),然后再在父级的基础上定位子级
方法一:
ele = driver.find_element(By.TAG_NAME,'main')
ele.find_element(By.XPATH,'//div/div/div[2]/div[1]/input').send_keys('子级')
方法二:
ele01 = driver.find_elements(By.CLASS_NAME,'input')
ele01[0].send_keys('子级')
2、兄弟姐妹定位
ele=driver.find_element(By.XPATH,'//div/div/div/div/input[contains(@placeholder,"用户名/手机号/邮箱")]')
ele.find_element(By.XPATH,'//../../div[2]/input').send_keys('11111')
3、定位父级
ele=driver.find_element(By.XPATH,'//div/div/div/div/input[contains(@placeholder,"用户名/手机号/邮箱")]')
ele.find_element(By.XPATH,'//..')
|