标签:顺序 sch 支持 use bdr 属性 对象 des bsp
# 提供八种定位方式
# 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上的定义如下:
语法
标签:顺序 sch 支持 use bdr 属性 对象 des bsp
原文地址:https://www.cnblogs.com/yago/p/11443675.html