首页 > 编程知识 正文

selenium css定位详解,selenium查找元素方法

时间:2023-05-04 07:52:31 阅读:46802 作者:795

大多数人在使用selenium定位器元素时都使用xpath定位器。 虽然css定位器容易被忽略,但实际上css定位器也有其价值,css定位器更快,语法更简洁

css的定位方法和上一篇的xpath的定位方法,两个学习

Selenium为CSS定位总结、CSS选择器二、CSS:属性定位三、CSS:其他属性四、CSS3360标签五、CSS:层次关系六、CSS3360索引七、CSS:逻辑运算八、百度搜索框

常用符号:

#表示id选择器

显示. class选择器

表示子元素,级别

空间也表示子元素,但它是所有后代的子元素,相当于xpath的相对路径

其次,css:属性位置CSS可通过三个常见属性(即元素的id、class和标签)直接定位

下面是百度输入框的html代码。 inputid=' kw ' class=' s _ ipt ' type=' text ' autocomplete=' off ' maxlength=' 100 ' name=' wd ' /

css以.表示class属性,如. s_ipt

css直接使用标签名称,没有标签。 示例:输入

三、css:其他属性CSS可以通过标签、class、id三个常规属性定位,也可以通过其他属性定位

以下格式[ name=wd ] [ autocomplete=' off ' ] [ maxlength=' 255 ' ]四、css:标签CSS可以通过标签和属性的组合来搜索元素

input.s _ ipt input # kw input [ id=' kw ' ]五、CSS:层次关系//form的id属性form#formspaninput//form的class属性form.fmspaninion

选择控件第三个Opel # selectselectoption : nth-child (3) checkbox第一个Volvo # checkbox input : nth-child (1) checkbox radioinput:nth-child(4)七、css:逻辑运算CSS同样可以实现逻辑运算,可以同时匹配两个属性,与xpath不同

[ type=' checkbox ' ] [ name=' checkbox1' ]

八、百度搜索框实例拿百度搜索框具体查看CSS定位

配置输入框

单属性定位typeselectordriver.find _ element _ by _ CSS _ selector (input ) ) id定位driver.find _ element _ by _ CSS _ selelector classpositiondriver.find _ element _ by _ CSS _ selector ('.s _ ipt ' )其他属性position driver.find _ element _ by e='text''] )组合属性配置id组合属性配置driver.find_element_by_CSS_ )。 class复合属性放置driver.find _ element _ by _ CSS _ selector (input.s _ ipt ) )其他属性放置driver.find _ element: 即使没有值,driver.find _ element _ by _ CSS _ selector (input [ name ] ) )其他两个属性也可以组合在一起

属性值的模糊匹配方法

1属性值由多个空格分隔,并与其中一个值匹配的方法driver.find _ element _ by _ CSS _ selector (input [ class~=' BTN ' ] ) 2属性值与字符串开头的方法driver.find_element匹配3与属性值字符串末尾匹配的方法driver.find _ element _ by _ CSS _ selector (input [ class ]

css可以通过三个常见属性直接放置:元素的id、class和标签

. css用#符号表示id属性,如下所示。

id=“kw”可以写为#kw

. c

ss用.表示class属性,如:
class="s_ipt"可以写成:.s_ipt
③. css直接用标签名称,无任何标识符,如:input

Xpath
xpath也可以通过元素的id、name、class这些属性定位
①. 用xpath通过id属性定位
driver.find_element(By.XPATH,"//[@id=‘kw’]")
②. 用xpath通过name属性定位
driver.find_element(By.XPATH,"//[@name=‘wd’]")
③. 用xpath通过class属性定位
driver.find_element(By.XPATH,"//*[@class=‘s_ipt’]")

其他属性

CSS
css除了上述以外,也可以通过其他属性定位
①. css通过name属性定位:
driver.find_element(By.CSS_SELECTOR,"[name=‘wd’]")
②. css通过autocomplete属性定位:
driver.find_element(By. CSS_SELECTOR,"[autocomplete=‘off’]")
③.css通过type属性定位:
driver.find_element(By.CSS_SELECTOR,"[type=‘text’]")

Xpath
没有上述属性,可以通过其他属性定位
driver.find_element(By.XPATH,"//*[@autocomplete=‘off’]")

标签

CSS
css页可以通过标签与属性的组合来定位元素
①. css通过标签与class属性的组合定位driver.find_element(By.CSS_SELECTOR,“input.s_ipt”)
②. css通过标签与id属性的组合定位driver.find_element(By.CSS_SELECTOR,“input#kw”)
③. css通过标签与其他属性组合定位driver.find_element(By.CSS_SELECTOR,“input[id=‘kw’]”)

Xpath
1、如果同一个属性,同名的比较多,可以通过标签筛选
①. 用xpath通过其他属性定位driver.find_element(By.XPATH,"//input[@autocomplete=‘off’]")
②. 用xpath通过id属性定位driver.find_element(By.XPATH,"//input[@id=‘kw’]")
③. 用xpath通过name属性定位driver.find_element(By.XPATH,"//name[@id=‘wd’]")

层级关系

CSS
如://form[@id=‘form’]/span/input和//form[@class=‘fm’]/span/input
①. css通过层级关系定位driver.find_element(By.CSS_SELECTOR,“form#form>span>input”)
②. css通过层级关系定位driver.find_element(By.CSS_SELECTOR,“form.fm>span>input”)

Xpath
1、如果一个元素,他的属性不明显,无法直接定位,可以先找到他的父元素,找到父元素,再找下一级就能定位
①. 通过定位父元素来定位input输入框driver.find_element(By.XPATH,"//span[@id=‘s_kw_wrap’]/input")
②. 通过定位爷元素来定位input输入框driver.find_element(By.XPATH,"//form[@id=‘form’]/span/input")

索引

CSS
1、css也可以通过索引option:nth-child(1)来定位子元素
①. 选择第一个子元素driver.find_element(By.CSS_SELECTOR,“select#nr>option:nth-child(1)”)
②. 选择第二个子元素driver.find_element(By.CSS_SELECTOR,“select#nr>option:nth-child(2)”)
③. 选择第三个子元素driver.find_element(By.CSS_SELECTOR,“select#nr>option:nth-child(3)”)

Xpath
1、可以通过排序定位
①. 用xpath定位第一位driver.find_element(By.XPATH,"//select[@id=‘nr’]/option[1]")
②. 用xpath定位第二位driver.find_element(By.XPATH,"//select[@id=‘nr’]/option[2]")
③. 用xpath定位第三位driver.find_element(By.XPATH,"//select[@id=‘nr’]/option[3]")

模糊匹配

CSS
driver.find_element(By.CSS_SELECTOR,“input:contains(‘kw’)”)

Xpath
1、xpath强大的模糊匹配
2、by_partial_link,模糊匹配定位
driver.find_element(By.XPATH,"//*[contains(text(),‘hao123’)]")

十一、总结

自动化测试Python+Selenium中对于web测试定位页面元素的两种主流XPATH和CSS定位方式
XPATH定位和CSS定位很相似,XPATH功能更强大一些,但CSS定位方式速度更快,但是某些浏览器不支持CSS定位,并且一般在自动化测试过程中使用xpath定位方式要比css更普遍

版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。