selenium 基本元素定位

Posted yago

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了selenium 基本元素定位相关的知识,希望对你有一定的参考价值。

 

# 提供八种定位方式
# 6种 针对唯一属性 2种组合定位-- 万能

from selenium import webdriver

driver = webdriver.Chrome()
driver.get("http://www.baidu.com")

ele = driver.find_element_by_id("kw")

print(ele.tag_name) # 打印标签名

ele.send_keys("柠檬班") # 在输入框输入文本

driver.find_element_by_tag_name("") # 找一个元素 找第一个匹配到的元素,从上到下

driver.find_elements_by_tag_name("") # 找一堆元素。 返回一个列表 列表中是 Webelement 对象

# 4 name 定位

driver.find_element_by_name("wd")
driver.find_elements_by_name("wd")

# 5 6 连接定位 a 元素 全匹配 部分匹配
driver.find_element_by_link_text("贴吧") # 全匹配
driver.find_element_by_partial_link_text("产品") # 部分

# 7 xpath - 万能

# css_selector css_selecter 选择器
# 绝对路径 严格按照 路径,同级元素的位置 页面一动,基本崩溃
# 以 / 开头, 父/子

# 相对路径 有一个参照物。 不考虑位置和路径 只考虑有还是有没有
# 以双斜杠开头
# 写法 //标签名[@属性名=值]
# 也可以包含and or //标签名[@属性名=值 and @属性名=值]
# 包含 //标签名[contains(@属性值,被包含的值)] , //input[contains(@class,username) and @name="phone"]
# 包含也 支持text()=值 //标签名[contains(text(),被包含的值)]
# * 匹配所有的 //*[@class="ss"] //input[@*="ss"]
# 层级定位 //div[@id="u"]//a[text()="登录"]

# 文本定位 text()=值 //标签名[text()=值]

# 轴定位
# /轴名称::节点名称[@属性=值] 例如://div//table//td//preceding::td 建议用 单斜杠
xpath= "//form[@id=‘form‘]/descendant::input[@id=‘su‘]"

# 轴运算 明确你的参照物
# ancestor 祖先节点 包括父
# parent 父节点
# preceding 当前元素节点标签之前的所有节点, html页面先后顺序
# preceding-sibling 当前元素节点标签之前的所有兄弟节点
# following 当前元素节点标签之后的所有节点 html 页面先后顺序
# following-sibling 当前元素节点标签之后的所有兄弟节点

w3cschool上的定义如下:

技术图片

语法

技术图片



以上是关于selenium 基本元素定位的主要内容,如果未能解决你的问题,请参考以下文章

selenium 基本元素定位

Selenium 定位元素原理,基本API,显示等待,隐式等待,重试机制等等

Selenium基本用法以及元素定位

selenium+python之元素定位方式介绍

selenium+Python元素定位

Python爬虫 Selenium -- Selenium元素定位Selenium访问元素信息Selenium交互