selenium自动化测试之元素定位三(css定位)

1.1 CSS定位

1.1.1 绝对路径定位

目标

查找第一个文本为“猜猜看”的a标签

实现

CSS表达式

html>body>div>a[.=”猜猜看”]

python表达式

driver.find_element_by_css_selector(‘html>body>div>a[.=”猜猜看”]’)

1.1.2 相对路径定位

目标

查找第一个文本为“猜猜看”的a标签

实现

CSS表达式

a[.=”猜猜看”]

Python表达式

driver.find_element_by_css_selector(‘a[.=”猜猜看”]’)

1.1.3 类名定位

目标

查找第一个类名为“blogpost-body”的div元素

实现

CSS表达式

div. blogpost-body

python表达式

driver.find_element_by_css_selector(“div. blogpost-body”)

说明

对于复合class,如<input class=”btn btn-lg btn-default” type=”text”>,直接写上所有的class即可,即:driver.find_element_by_css_selector(“input. btn.btn-lg.btn-default”)

标签名不是必须的

1.1.4 属性定位

1.1.4.1 ID属性定位

目标

查找页面中第一个id为“cnblogs_post_body”div元素

实现

CSS表达式

div# cnblogs_post_body

Python表达式

driver.find_element_by_css_selector(“div# cnblogs_post_body”)

1.1.4.2 其他属性定位

其他属性是指除id、class以外的所有属性,如img的src、alt属性,input的type、placeholder等

目标

查找页面中alt属性等于"点我试试呀"的img元素

实现

CSS表达式

img[alt=”点我试试呀”]

Python表达式

driver.find_element_by_css_selector(‘img[alt=”点我试试呀”]’)

说明

如果单独依靠某个属性无法唯一定位元素,则可以写多个属性,如下:

img[alt=”点我试试呀”][src=”/images/bg.jpg”]

driver.find_element_by_css_selector(‘img[alt=”点我试试呀”] [src=”/images/bg.jpg”]’)

1.1.4.3 模糊属性定位

模糊属性定位经常使用的三个正则表达式^、$、*

目标

查找链接地址是“http://www.baidu.com”的a标签

CSS表达式

a[href^=”http://www.baidu”]

a[href$=”baidu.com”]

a[href*=”baidu”]

python表达式

find_element_by_css_selector(‘a[href^=”http://www.baidu”]’)

find_element_by_css_selector(‘a[href^=” a[href$=”baidu.com”]’)

find_element_by_css_selector(‘a[href*=”baidu”]’)

1.1.5 子页面元素查找

目标

查找id为home的div下的class为highlighter-rouge的div

CSS表达式

div#home>div.highlighter-rouge

python表达式

driver.find_element_by_css_selector(“div#home>div.highlighter-rouge”)

1.1.6 伪类定位

目标

查找div#home下的第一个子元素

CSS表达式

div#home :first-child

python表达式

dirver..find_element_by_css_selector(“div#home :first-child”)

附录:

CSS伪类

1.1 CSS伪类


选择器


示例


示例说明


:checked


input:checked


选择所有选中的表单元素


:disabled


input:disabled


选择所有禁用的表单元素


:empty


p:empty


选择所有没有子元素的p元素


:enabled


input:enabled


选择所有启用的表单元素


:first-of-type


p:first-of-type


选择每个父元素是p元素的第一个p子元素


:in-range


input:in-range


选择元素指定范围内的值


:invalid


input:invalid


选择所有无效的元素


:last-child


p:last-child


选择所有p元素的最后一个子元素


:last-of-type


p:last-of-type


选择每个p元素是其母元素的最后一个p元素


:not(selector)


:not(p)


选择所有p以外的元素


:nth-child(n)


p:nth-child(2)


选择所有 p 元素的父元素的第二个子元素


:nth-last-child(n)


p:nth-last-child(2)


选择所有p元素倒数的第二个子元素


:nth-last-of-type(n)


p:nth-last-of-type(2)


选择所有p元素倒数的第二个为p的子元素


:nth-of-type(n)


p:nth-of-type(2)


选择所有p元素第二个为p的子元素


:only-of-type


p:only-of-type


选择所有仅有一个子元素为p的元素


:only-child


p:only-child


选择所有仅有一个子元素的p元素


:optional


input:optional


选择没有"required"的元素属性


:out-of-range


input:out-of-range


选择指定范围以外的值的元素属性


:read-only


input:read-only


选择只读属性的元素属性


:read-write


input:read-write


选择没有只读属性的元素属性


:required


input:required


选择有"required"属性指定的元素属性


:root


root


选择文档的根元素


:target


#news:target


选择当前活动#news元素(点击URL包含锚的名字)


:valid


input:valid


选择所有有效值的属性


:link


a:link


选择所有未访问链接


:visited


a:visited


选择所有访问过的链接


:active


a:active


选择正在活动链接


:hover


a:hover


把鼠标放在链接上的状态


:focus


input:focus


选择元素输入后具有焦点


:first-letter


p:first-letter


选择每个<p> 元素的第一个字母


:first-line


p:first-line


选择每个<p> 元素的第一行


:first-child


p:first-child


选择器匹配属于任意元素的第一个子元素的 <p> 元素


:before


p:before


在每个<p>元素之前插入内容


:after


p:after


在每个<p>元素之后插入内容


:lang(language)


p:lang(it)


为<p>元素的lang属性选择一个开始值

原文地址:https://www.cnblogs.com/ianduin/p/12684448.html

时间: 2024-08-12 10:47:51

selenium自动化测试之元素定位三(css定位)的相关文章

Selenium自动化测试之元素定位

一.Selenium定位方法 自动化测试的关键是要准确的操作测试对象,所以就需要对被测系统的页面元素做精确的定位:有以下几种定位方法: By.classNme(String className) By.cssSelector(String selector) By.id(String id) By.linkText(String linkText) By.name(String name) By.partialLinkText(String linkText) By.tagName(String

selenium自动化测试之元素定位一

Selenium元素定位方法总共有八大类,分别是:id,name,class name,tag name,link text,partial link text,xpath,css.八种定位方法没有哪个是最好的,在不同的场景下需要使用不用的定位方法. 示例html文件如下: <!DOCTYPE html> <html lang="zh-cn"> <head> <meta charset="utf-8"/> <me

selenium自动化测试之元素定位二(xpath定位)

1.1 Xpath定位 1.1.1 选取节点 1.1.1.1 精确选择节点 XPath 使用路径表达式在 XML 文档中选取节点.节点是通过沿着路径或者 step 来选取的 路径表达式 表达式 描述 nodename 选取此节点的所有子节点. / 从根节点选取. // 从匹配选择的当前节点选择文档中的节点,而不考虑它们的位置. . 选取当前节点. .. 选取当前节点的父节点. @ 选取属性. 1.1.1.2 选取未知节点 XPath 通配符可用来选取未知的 XML 元素. 通配符 描述 * 匹配

CSS定位(CSS定位概述、相对定位、绝对定位、浮动)

CSS 定位属性 CSS 定位属性允许你对元素进行定位. 属性 描述 position 把元素放置到一个静态的.相对的.绝对的.或固定的位置中. top 定义了一个定位元素的上外边距边界与其包含块上边界之间的偏移. right 定义了定位元素右外边距边界与其包含块右边界之间的偏移. bottom 定义了定位元素下外边距边界与其包含块下边界之间的偏移. left 定义了定位元素左外边距边界与其包含块左边界之间的偏移. overflow 设置当元素的内容溢出其区域时发生的事情. clip 设置元素的

Selenium 自动化测试之道--学习总结-WebDriver

最近正在看Ping++测试团队编著的<Selenium 自动化测试之道>,非常非常好的一本书,不仅仅是工具的介绍使用,还有非常珍贵的实践总结,自己的公司也在做自动化,由于是基于B/S,要考虑到硬件环境,而且主要使用的是RobotFramework去构建自动化脚本验证系统的可靠性. 之前自己也学习过关于Selenium的知识,但是总感觉知识很零散,自己在网上搜了很长时间,买了这本书,发现自己还欠缺很多,很庆幸能读到这本书,下面开始一点点的搭建自己的知识框架. 一.工作原理 Selenium We

Selenium自动化测试之学会元素定位

这是我经常被问到的一个问题,也是我很讨厌回答的问题,因为要想回答这个问题需要知道上下文.什么样式的元素,有哪些属性,是否有表单嵌套,都尝试了哪些定位方法...而且没几个提问者能事先详细的说明这些.哪儿像提bug一样描述重现步骤,而且每一步都截图,生怕开发重现不了.反正,向我提问者没见过这样的,大多就报着试试态度,你爱回不回,碰碰运气说不定就回我了. 当然,我写这一篇文章的目的肯定不是为了吐槽,我是打算拿这个链接丢给他看,所以,这里会总结常见几种情况,以及解决办法.如果本文能不解决你的问题,你问我

【Selenium 3+Java自动化(6)】-CSS定位语法

一.前言 本章节讲解一下CSS定位. CSS定位相对于XPath定位的优点是:css定位更快,语法更简洁. 这一篇css的定位方法,主要是对比上一篇的xpath来的,基本上xpath能完成的,css也可以做到.两篇对比学习,更容易理解. 二.CSS:属性定位 1.通过id属性定位,需要加上标识符"#",如:#kw: element = driver.findElement(By.cssSelector("#kw")); element.sendKeys("

xpath定位和css定位

元素定位是web自动化测试最开始也是最重要的一个知识点. 学会了元素定位,也就完成了一个学习的里程碑. 但是有很多初学者最容易犯的错误就是在Chrome或Firefox中复制出定位语句. 这样做是不正确的,因为很多复制出来的语句是绝对定位的语句,网页发生一点变化,就会出现找不到元素的情况. 所以在实际写元素定位语句的时候,我们应该避免使用绝对路径语法进行定位,多使用相对路径定位语法进行定位. 苦于自己学识浅薄无法推出这方面的教程,但是自己找到了一个非常好的关于xpath和css定位的语法教程.

Selenium自动化测试之基本控件使用

1.输入框input: 在Html中样式: <input id="username" type="text"> 操作: driver.findElement(By.id("username")).clear(); driver.findElement(By.id("username")).sendKeys("test"); 说明: clear表示清除输入框中的数据: sendKeys表示向输入框