目录
前言1:id定位2:name定位3:class_name定位4:tag_name定位5:link_text定位6:partial_link_text定位7:xpath定位8:css定位前言
八种定位方式:
id,name,class name,tag name,link text,partial link text,xpath,css selector。其中id,name,class name,tag name是根据元素的标签或元素的属性来进行定位;link text,partial link text是根据超链接的文本来进行定位;xpath为元素路径定位;css为选择器定位(样式定位)。
(资料图片仅供参考)
1:id定位
说明:id定位就是通过元素的id属性来定位元素;
前提:元素有id属性
id定位方法:find_element_by_id()
示例:打开百度搜索页面,通过id定位,输入搜索关键字
from selenium import webdriver import time # 打开chrome浏览器 driver = webdriver.Chrome() # 打开百度搜索页面 driver.get("https://www.baidu.com") # 通过id定位 driver.find_element_by_id("kw").send_keys("python") # 强制等待2秒查看效果 time.sleep(2) # 关闭浏览器 driver.quit()
2:name定位
说明:HTML规定name属性来指定元素名称,name的属性值在当前文档中可以不是唯一的,name定位就是根据name属性来定位。
前提:元素有name属性
name定位方法:find_element_by_name()
示例:打开百度搜索页面,通过name定位,输入搜索关键字
from selenium import webdriver import time # 打开chrome浏览器 driver = webdriver.Chrome() # 打开百度搜索页面 driver.get("https://www.baidu.com") # 通过name定位 driver.find_element_by_name("wd").send_keys("python") # 强制等待2秒查看效果 time.sleep(2) # 关闭浏览器 driver.quit()
3:class_name定位
说明:HTML规定class来指定元素的类名,class定位就是根据class属性来定位。
前提:元素有class属性
class_name定位方法:find_element_by_class_name()
示例:打开百度搜索页面,通过class_name定位,输入搜索关键字
from selenium import webdriver import time # 打开chrome浏览器 driver = webdriver.Chrome() # 打开百度搜索页面 driver.get("https://www.baidu.com") # 通过class_name定位 driver.find_element_by_class_name("s_ipt").send_keys("python") # 强制等待2秒查看效果 time.sleep(2) # 关闭浏览器 driver.quit()
4:tag_name定位
说明:HTML本质就是由不同的tag(标签)组成,而每个tag都是指同一类,所以tag定位效率低,一般不建议使用;tag_name定位就是通过标签名来定位。
tag_name定位方法:find_element_by_tag_name()
5:link_text定位
说明:link_text定位与前面4个定位有所不同,它专门用来定位超链接文本(文本值)
前提:定位的元素是链接标签(a标签)
link_text定位方法:find_element_by_link_text()
示例:打开百度首页,通过link_text定位到hao123按钮,并进行点击操作
from selenium import webdriver import time # 打开chrome浏览器 driver = webdriver.Chrome() # 打开百度搜索页面 driver.get("https://www.baidu.com") # 通过link_text定位 driver.find_element_by_link_text("hao123").click() # 强制等待2秒查看效果 time.sleep(2) # 关闭浏览器 driver.quit()
6:partial_link_text定位
说明:partial_link_text定位是对link_text定位的补充,partial_link_text为模糊匹配;link_text为精确匹配。
前提:定位的元素是链接标签(a标签)
partial_link_text定位方法:find_element_by_partial_link_text()
通过传入a标签局部文本或全部文本来定位元素,要求输入的文本能够唯一找到这个元素
示例:打开百度首页,通过partial_link_text定位到新闻,并进行点击操作
from selenium import webdriver import time # 打开chrome浏览器 driver = webdriver.Chrome() # 打开百度搜索页面 driver.get("https://www.baidu.com") # 通过partial_link_text定位 driver.find_element_by_partial_link_text("新").click() # 强制等待2秒查看效果 time.sleep(2) # 关闭浏览器 driver.quit()
7:xpath定位
xpath概述:
1、xpath即为xml path的简称,它是一种用来确定XML文档中某部分位置的语言。2、HTML可以看做是XML的一种实现,所以selenium用户可以使用这种强大的语言在web应用中来定位元素。3、xpath为强大的语言,是因为它有非常灵活的定位策略。xpath定位策略(方式):
1、路径定位–绝对路径、相对路径;2、利用元素属性定位;3、层级与属性结合定位;4、属性与逻辑定位结合。xpath定位方法:find_element_by_xpath()
8:css定位
css概述:
1、css(Cascading Style Sheets)是一种语言,它用来描述HTML和XML的元素显示样式。2、css语言中有css选择器,在selenium中也可以使用这种选择器来进行元素定位。3、css定位方式比xpath快,而且css的语法也非常强大,所以非常推荐这种方式定位。css定位策略(方式):
1、id选择器2、class选择器3、元素选择器4、属性选择器5、层级选择器css定位方法:find_element_by_css_selector()
到此这篇关于Python selenium 八种定位元素的方式的文章就介绍到这了,更多相关Python selenium 内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
X 关闭
X 关闭
- 1联想拯救者Y70发布最新预告:售价2970元起 迄今最便宜的骁龙8+旗舰
- 2亚马逊开始大规模推广掌纹支付技术 顾客可使用“挥手付”结账
- 3现代和起亚上半年出口20万辆新能源汽车同比增长30.6%
- 4如何让居民5分钟使用到各种设施?沙特“线性城市”来了
- 5AMD实现连续8个季度的增长 季度营收首次突破60亿美元利润更是翻倍
- 6转转集团发布2022年二季度手机行情报告:二手市场“飘香”
- 7充电宝100Wh等于多少毫安?铁路旅客禁止、限制携带和托运物品目录
- 8好消息!京东与腾讯续签三年战略合作协议 加强技术创新与供应链服务
- 9名创优品拟通过香港IPO全球发售4100万股 全球发售所得款项有什么用处?
- 10亚马逊云科技成立量子网络中心致力解决量子计算领域的挑战