1. id定位
# id定位,属性 + 操作 = 返回 webELement 对象
ele1 = driver.find_element_by_id("kw")
print(ele1)
2. 标签名定位 tag_name
不能唯一的找到特定的元素
ele2 = driver.find_element_by_tag_name("input") # (译:泰格.内幕)在dom页面当中,匹配到的第一个元素
print(ele2)
eles = driver.find_elements_by_tag_name("input") # 列表,元素为webELement对象 全部匹配的元素
print(eles)
3.class_name 定位
不能唯一的找到特定的元素
driver.find_element_by_class_name("s_ipt")
driver.find_elements_by_class_name("s_ipt")
4.name 定位 不唯一
driver.find_element_by_name("wd")driver.find_elements_by_name("wd")
以上四种元素定位针对所有元素
5.link_text 定位,完整匹配文本值driver.find_element_by_link_text("更多产品") # (译:林可.泰克斯特)
6.partial_link_text 定位,部分匹配上
driver.find_element_by_partial_link_text("产品") # (译:抛售.林可.泰克斯特)
7. xpath 定位
语法
-
/:绝对定位 —— 一般不用,兼容性太差
-
//:
-
相对定位 —— 一般用相对定位,来进行定位
-
从匹配选择的当前节点选择文档中的节点,而不考虑它们的位置
-
-
.:选取当前节点
-
..:选取当前节点的父节点
-
@:
-
选取属性
-
@class="xxx" ,shuxing 属性放在中括号 【】中
-
-
*:通配符。匹配所有 //*
-
@*:通配符。匹配所有属性 //*[@*="hello"]
-
多条件查询,使用逻辑查询
-
and 全部为真
-
or 其中一个为真
-
语法://input[@id="kw" and @name="wd"]
-
浏览器的快捷键 F12 ----> Ctrl + F 打开定位栏
1、使用:标签名 + 节点属性定位
-
语法://标签名[@属性名=值]
-
//input[@id="kw" and @name="wd"]
2、使用:文本内容匹配:函数:text()
-
文本全部匹配:text()="文本内容"
-
//a[text()="更多产品"]
-
-
文本部分匹配:contains(text(),部分文本内容)
-
(译:康ten死)
-
//a[contains(text(),"产品")]
-
3、通过部分属性值匹配
-
语法://标签名[contains(@属性名,部分属性值)]
-
//a[contains(@href,"om/more/") and @class="bri"]
4、层级定位:
-
先确定节点的父节点,在找子节点
-
//div[@id="u1"]//a[@name="tj_login"]
5、xpath轴定位语法
使用语法: 已知的元素定位/下面的轴名称::标签名称[@属性=值] 例://p[@title="2016"]/following-sibling::p[@class="name"] 轴名称及意思
-
ancestor:(译:昂赛斯 特儿) 当前节点之前的所有父节点
parent
-
:(译:潘润特) 当前节点的父节点
-
preceding:(译:普瑞 sei 定) 当前节点之前的所有节点
preceding-sibling
-
:(译:普瑞 sei 定。塞玻璃) 当前节点之前的所有同级节点
-
following:(译:fao lin) 当前节点之后的所有节点
following-sibling
-
:(译:fao lin 。塞玻璃)当前节点之后的所有同级节点
-
child 当前节点的子节点
-
self 当前节点本身
8. css 定位------自行搞定
浏览器自带的css、xpath、js定位方式
本文详细介绍了Python中利用Webdriver进行网页元素定位的技巧,包括id、标签名、class_name、name以及link_text和xpath定位。理解这些方法有助于提升自动化测试和网页爬虫的效率。
200





