『心善渊』Selenium3.0基础 — 8、使用CSS选择器定位元素
1、CSS选择器介绍
CSS(Cascading Style Sheets)是一种语言,它被用来描述HTML 和XML 文档的表现。CSS 使用选择器来为页面元素绑定CSS属性。这些选择器可以被Selenium 用作另外的定位策略。
by_css_selector通过CSS选择器查找元素,这种元素定位方式跟by_xpath比较类似,Selenium官网的Document里极力推荐使用CSS locator,而不是XPath来定位元素。原因是CSS locator比XPath locator速度快,特别是在IE下,CSS locator比XPath更高效更准确更易编写,对各种浏览器支持也很好。
2、CSS选择器定位语法
(1)单数定位,获得一个指定元素对象
driver.find_element_by_css_selector(“css选择器定位策略”)
(2)复数定位,获得指定元素结果集列表
driver.find_elements_by_css_selector(“css选择器定位策略”)
3、Selenium中使用CSS选择器定位元素
(1)通过属性定位元素
CSS选择器可以通过元素的id、class、标签这三个常规属性直接定位到目标元素。
页面中代码如下:
<input type="telA" name="telA" id="telA" placeholder="电话A" class="telA" value="">
需求:使用CSS选择器通过id,class和其他属性,定位页面中的电话A<input>标签。
"""
1.学习目标:
必须掌握selenium中css定位方法
2.语法
2.1 在selenium中语法
(1)driver.find_element_by_css_selector("css选择器定位策略")
(2)driver.find_elements_by_css_selector("css选择器定位策略")
2.2 css表达式写法
(1)#表示id属性
#id属性值 例如: #telA
(2).表示class属性
.class属性值 例如: .telA
(3)其他属性
[属性名=属性值] 例如: [name=telA]
3.需求
在页面中,使用css定位电话A输入框
"""
# 1.导入selenium
from selenium import webdriver
from time import sleep
import os
# 2.打开浏览器
driver = webdriver.Chrome()
# 3.打开页面
url = "file:///" + os.path.abspath("./练习页面/注册A.html")
driver.get(url)
# 4.定位电话A标签,使用css selector
# 4.1 通过id定位
telA_1 = driver.find_element_by_css_selector("#telA")
print(telA_1.get_attribute("outerHTML"))
# 4.2 通过class属性定位
telA_2 = driver.find_element_by_css_selector(".telA")
print(telA_2.get_attribute("outerHTML"))
# 4.3 通过其他属性定位
telA_3 = driver.find_element_by_css_selector("[name='telA']")
print(telA_3.get_attribute("outerHTML"))
# 5.关闭浏览器
sleep(2)
driver.quit()
"""
输出结果:
<input type="telA" name="telA" id="telA" placeholder="电话A" class="telA" value="">
<input type="telA" name="telA" id="telA" placeholder="电话A" class="telA" value="">
<input type="telA" name="telA" id="telA" placeholder="电话A" class="telA" value="">
"""
(2)通过标签定位元素
CSS选择器也可以通过标签与属性的组合来定位元素。
在页面中有如下代码:
<input type="telA" name="telA" id="telA" placeholder="电话A" class="telA" value="">
需求:使用CSS选择器通过标签+属性定位页面中的电话A<input>标签。
"""
1.学习目标:
必须掌握selenium中css定位方法
2.语法
2.1 在selenium中语法
(1)driver.find_element_by_css_selector("css选择器定位策略")
(2)driver.find_elements_by_css_selector("css选择器定位策略")
2.2 css表达式写法
标签+属性
格式:标签名[属性名=属性值]
3.需求
在页面中,使用css定位电话A输入框
"""
# 1.导入selenium
from selenium import webdriver
from time import sleep
import os
# 2.打开浏览器
driver = webdriver.Chrome()
# 3.打开页面
url = "file:///" + os.path.abspath("./练习页面/注册A.html")
driver.get(url)
# 4.定位电话A标签,使用css selector
# 标签+属性
# 通过name属性
telA = driver.find_element_by_css_selector("input[name='telA']")
# 通过id属性
telA_1 = driver.find_element_by_css_selector("input#telA")
print(telA.get_attribute("outerHTML"))
print(telA_1.get_attribute("outerHTML"))
# 5.关闭浏览器
sleep(2)
driver.quit()
"""
输出结果:
<input type="telA" name="telA" id="telA" placeholder="电话A" class="telA" value="">
<input type="telA" name="telA" id="telA" placeholder="电话A" class="telA" value="">
"""
(3)通过层级关系定位元素
在前面XPath中讲到层级关系定位,这里CSS选择器也可以达到同样的效果。
在页面中有如下代码:
<p id="p1">
<label for="userA">账号A</label>
<input type="textA" name="userA" id="userA" placeholder="账号A" required="" value=""> </p>
需求:使用CSS选择器通过层级定位的方式,定位页面中的账号A<input>标签。
"""
1.学习目标:
必须掌握selenium中css定位方法
2.语法
2.1 在selenium中语法
(1)driver.find_element_by_css_selector("css选择器定位策略")
(2)driver.find_elements_by_css_selector("css选择器定位策略")
2.2 css表达式写法
层级定位 需要使用 > 或 空格表示层级关系
格式:父标签名[父标签属性名=属性值]>子标签名
3.需求
在页面中,使用css定位账号A输入框
"""
# 1.导入selenium
from selenium import webdriver
from time import sleep
import os
# 2.打开浏览器
driver = webdriver.Chrome()
# 3.打开页面
url = "file:///" + os.path.abspath("./练习页面/注册A.html")
driver.get(url)
# 4.定位账号A标签,使用css selector层级定位
textA_1 = driver.find_element_by_css_selector("p#p1 input")
print(textA_1.get_attribute("outerHTML"))
# 5.关闭浏览器
sleep(2)
driver.quit()
"""
输出结果:
<input type="textA" name="userA" id="userA" placeholder="账号A" required="" value="">
"""
(4)通过索引定位元素
语法格式:
- 表示父标签下所有子标签顺序
父标签[父标签属性名=父标签属性值]>:nth-child(索引值) - 表示父标签下具体标签的第几个标签
父标签[父标签属性名=父标签属性值]>子标签:nth-of-type(索引值)
在页面中有如下代码:
<div id="zc">
<fieldset>
<legend>注册用户A</legend>
<p id="p1">
<label for="userA">账号A</label>
<input type="textA" name="userA" id="userA" placeholder="账号A" required="" value="">
</p>
<p>
<label for="password">密码A</label>
<input type="password" name="passwordA" id="passwordA" placeholder="密码A" value="">
</p>
</fieldset>
</div>
需求:使用CSS选择器通过层级定位的方式,定位页面中的账号A<input>标签。
"""
1.学习目标:
必须掌握selenium中css定位方法
2.语法
2.1 在selenium中语法
(1)driver.find_element_by_css_selector("css选择器定位策略")
(2)driver.find_elements_by_css_selector("css选择器定位策略")
2.2 css表达式写法
索引定位
(1)父标签名[父标签属性名=属性值]>:nth-child(索引值)
从父标签下所有标签开始计算
(2)父标签名[父标签属性名=属性值]>子标签名:nth-of-type(索引值)
表示父标签下具体标签的第几个标签
3.需求
在页面中,使用css定位账号A输入框
"""
# 1.导入selenium
from selenium import webdriver
from time import sleep
import os
# 2.打开浏览器
driver = webdriver.Chrome()
# 3.打开注册A页面
url = "file:///" + os.path.abspath("./练习页面/注册A.html")
driver.get(url)
# 4. 使用css索引定位账号A输入框
textA_1 = driver.find_element_by_css_selector("fieldset>:nth-child(2)>input")
textA_2 = driver.find_element_by_css_selector("fieldset>p:nth-of-type(1)>input")
print(textA_1.get_attribute("outerHTML"))
print(textA_2.get_attribute("outerHTML"))
# 5.关闭浏览器
sleep(2)
driver.quit()
"""
输出结果:
<input type="textA" name="userA" id="userA" placeholder="账号A" required="" value="">
<input type="textA" name="userA" id="userA" placeholder="账号A" required="" value="">
"""
(5)通过逻辑运算定位元素
CSS选择器同样也可以实现逻辑运算,同时匹配两个属性,这里跟XPath不一样,无需写and关键字。
在页面中有如下代码
<input type="telA" name="telA" id="telA" placeholder="电话A" class="telA" value="">
需求:使用CSS选择器通过逻辑运算定位的方式,定位页面中的电话A<input>标签。
"""
1.学习目标:
必须掌握selenium中css定位方法
2.语法
2.1 在selenium中语法
(1)driver.find_element_by_css_selector("css选择器定位策略")
(2)driver.find_elements_by_css_selector("css选择器定位策略")
2.2 css表达式写法
逻辑定位
格式:标签名[属性名1=属性值1][属性名2=属性值2]...
注意:属性与属性之间不能用空格
3.需求
在页面中,使用css定位电话A输入框
"""
# 1.导入selenium
from selenium import webdriver
from time import sleep
import os
# 2.打开浏览器
driver = webdriver.Chrome()
# 3.打开注册A页面
url = "file:///" + os.path.abspath("./练习页面/注册A.html")
driver.get(url)
# 4. 使用css逻辑定位---电话A输入框
# 注意:两个属性之间不能加空格,空格表示层级关系
telA = driver.find_element_by_css_selector("input[type='telA'][placeholder='电话A']")
print(telA.get_attribute("outerHTML"))
# 5.关闭浏览器
sleep(2)
driver.quit()
"""
输出结果:
<input type="telA" name="telA" id="telA" placeholder="电话A" class="telA" value="">
"""
(6)通过模糊匹配定位元素
css_selector有三种模糊匹配方式:
^:匹配到id属性值的头部,如ctrl_12driver.find_element_by_css_selector("input[id^='ctrl']")
$:匹配到id属性值的尾部,如a_ctrldriver.find_element_by_css_selector("input[id$='ctrl']")
*:匹配到id属性值的中间,如1_ctrl_12driver.find_element_by_css_selector("input[id*='ctrl']")
在页面中有如下代码:
<button type="submitA" value="注册A" title="加入会员A">注册用户A</button>
需求:在页面中,使用CSS选择器定位注册用户A按钮
"""
1.学习目标:
必须掌握selenium中css定位方法
2.语法
2.1 在selenium中语法
(1)driver.find_element_by_css_selector("css选择器定位策略")
(2)driver.find_elements_by_css_selector("css选择器定位策略")
2.2 css表达式写法
模糊匹配:匹配属性值
(1)* :匹配所有
(2)^ :匹配开头
(3)$ :匹配结尾
3.需求
在页面中,使用css定位注册用户A按钮
"""
# 1.导入selenium
from selenium import webdriver
from time import sleep
import os
# 2.打开浏览器
driver = webdriver.Chrome()
# 3.打开注册A页面
url = "file:///" + os.path.abspath("./练习页面/注册A.html")
driver.get(url)
# 4. 使用css模糊匹配定位---注册用户A按钮
button_1 = driver.find_element_by_css_selector("button[type^='su']")
print(button_1.get_attribute("outerHTML"))
button_2 = driver.find_element_by_css_selector("button[value$='册A']")
print(button_2.get_attribute("outerHTML"))
button_3 = driver.find_element_by_css_selector("button[title*='入会']")
print(button_3.get_attribute("outerHTML"))
# 5.关闭浏览器
sleep(2)
driver.quit()
"""
输出结果:
<button type="submitA" value="注册A" title="加入会员A">注册用户A</button>
<button type="submitA" value="注册A" title="加入会员A">注册用户A</button>
<button type="submitA" value="注册A" title="加入会员A">注册用户A</button>
"""
4、总结:
这里指做了一些最常用的css_selector定位方式的练习。
如果在工作中有需要用到一些特别的用法,可以查看css_selector的文档。
CSS选择器的文档地址:https://www.w3school.com.cn/cssref/css_selectors.asp
『心善渊』Selenium3.0基础 — 8、使用CSS选择器定位元素的更多相关文章
- 『心善渊』Selenium3.0基础 — 10、使用Seleniun定位页面元素归纳总结(超详细)
目录 1.Selenium中8种基本元素定位方式 (1)单数形式 (2)复数形式 2.By类定位的8种定位方式 (1)单数形式 (2)复数形式 3.XPath定位总结 (1)基础定位语法 (2)属性定 ...
- 『心善渊』Selenium3.0基础 — 7、XPath轴定位详解
目录 1.XPath轴定位介绍 2.位置路径表达式概念 3.步的路径表达式范例 4.练习 使用XPath轴方式,可根据文档中元素的相对位置,来进行元素的定位.例如:先找到一个相对好定位的元素,在根据与 ...
- 『心善渊』Selenium3.0基础 — 24、Selenium的expected_conditions模块详细介绍
目录 1.EC模块介绍 2.EC模块常用类 3.EC模块的使用 4.EC模块综合使用 (1)title_is(title)示例 (2)presence_of_element_located(locat ...
- 『心善渊』Selenium3.0基础 — 11、Selenium对元素常用操作
目录 1.Selenium对元素常用操作 2.Selenium对元素的其他操作 1.Selenium对元素常用操作 操作 说明 click() 单击元素 send_keys() 模拟输入 clear( ...
- 『心善渊』Selenium3.0基础 — 12、Selenium操作鼠标和键盘事件
目录 (一)对鼠标的操作 1.鼠标事件介绍 2.ActionChains 类鼠标操作的常用方法 3.perform()方法 4.鼠标事件操作步骤 5.示例 (1)右键单击.左键双击 (2)鼠标拖拽动作 ...
- 『心善渊』Selenium3.0基础 — 1、Selenium自动化测试框架介绍
目录 1.Selenium介绍 2.Selenium的特点 3.Selenium版本说明 4.拓展:WebDriver与Selenium RC的区别 5.Webdriver工作原理 1.Seleniu ...
- 『心善渊』Selenium3.0基础 — 4、Selenium基础元素定位详解
目录 1.什么是元素定位 2.Selenium元素定位常用API (1)By_id 定位 (2)by_name 定位 (3)by_class_name 定位 (4)by_tag_name 定位 (5) ...
- 『心善渊』Selenium3.0基础 — 5、XPath路径表达式详细介绍
目录 1.XPath介绍 2.什么是XML 3.XML与HTML对比 4.为什么使用XPath定位页面中的元素 5.XPath中节点之间的关系 (1)节点的概念 (2)节点之间的关系类型 6.XPat ...
- 『心善渊』Selenium3.0基础 — 6、Selenium中使用XPath定位元素
目录 1.Selenium中使用XPath查找元素 (1)XPath通过id,name,class属性定位 (2)XPath通过标签中的其他属性定位 (3)XPath层级定位 (4)XPath索引定位 ...
- 『心善渊』Selenium3.0基础 — 16、Selenium对iframe表单的操作
目录 1.什么是iframe表单 2.iframe表单操作流程 3.iframe表单操作常用方法 (1)进入表单 (2)多表单切换 4.表单操作示例 1.什么是iframe表单 实际上就是HTML页面 ...
随机推荐
- [敏杰开发]知识路书——图形化文献管理大师 Beta版发布喽!!!
[敏杰开发]知识路书--图形化文献管理大师 Beta版发布喽!!! 一.总览 项目名称:知识路书 发布形式:网页应用 发布地址:http://roadmap.imcoming.top 二.运行环境与使 ...
- 29.Map,可变参数
1.Map集合 1.1Map集合概述和特点[理解] 单列集合一次存一个元素 双列集合一次存两个元素 键:不能重复的 值:可以重复的 Map集合概述 interface Map<K, ...
- [bug] CDH安装中断 再次安装显示当前受管 无法选择
参考 https://blog.csdn.net/JacksonKing/article/details/104350313 重装 https://blog.csdn.net/simle168/art ...
- [刷题] 300 Longest Increasing Subsequence
要求 给定一个整数序列,求其中的最长上升子序列长度 子序列元素可不相邻 元素相等不算上升 一个序列可能有多个最长上升子序列,但最长的长度只有一个 思路 暴力解法:选择所有子序列进行判断((2^n)*n ...
- sed 's/AA/BB/' file # 将文件中的AA替换成BB,只替换一行中第一次出现的AA,替换后的结果输出到屏幕 sed 's/AA/BB/g' file # 将文件中的所有AA都替换成BB,替换后的结果输出到屏幕
生信人的自我修养:Linux命令速查手册 简佐义 四川大学 生物信息学硕士 科学求真 赢 10 万奖金 · 院士面对面 209 人赞同了该文章 许多人做生物信息学,要么不重视Linux,要么不知道 ...
- Linux_计划任务
[Centos7.4] !!!测试环境我们首关闭防火墙和selinux:免得后面的测试会出现问题 [root@localhost ~]# systemctl stop firewalld [root@ ...
- IT菜鸟之网线制作
网线是属于OSI七层模型中的物理层:网络中的数据传输媒介 备注:OSI七层模型后面会记录 网线制作所需要的资源素材: 1.网线 2.水晶头(类型:电话线RJ11,宽带线RJ45) 3.网线钳(非必需) ...
- 第35章-CentOS7实战
补充安装软件包 yum -y install vim lrzsz bash-completion telnet nmap 关闭selinux:/etc/selinux/config 关闭防火墙:sys ...
- MyBaits 全局配置文件(mybatis-config.xml)
什么是 MyBatis 全局配置文件 MyBatis 全局配置文件包含影响 MyBatis 框架正常使用的功能设置和属性信息. 它的作用好比手机里的设置图标,点击这个图标就可以帮助我们查看手机的属性信 ...
- SSM框架的配置整合(包含配置文件代码)
由于SSM框架学习都要去网上或者以前的项目拷贝相同的代码,所以我在此把自己用到的配置文件全放在这里,帮助自己,帮助别人 首先开始前导入依赖和处理静态资源导出问题 <dependencies> ...