/html/body/div[1]/div/div/div/div[2]/div/div/button
注:这种方法,一旦路径有变化会导致定位失败,所以不推荐使用绝对路径方式。
//*[@id="csdn-toolbar"]/div/div/div[1]/ul/li[5]/a
//button[@id="toolbar-search-button"]
//input[@type="password" and @autocomplete="new-password"]
//span[text()="搜索"]
//button[starts-with(@id,'t')]
//img[contains(@src,'20220107105619')]
父节点
,也就是当前节点上一级节点//a[text()="教程"]/parent::li
子节点
,也就是当前节点的下一级节点//div[contains(@class,'addZ-index')]/child::div[1]
上层节点
//div[contains(@class,'addZ-index')]/ancestor::body
下层节点
//div[contains(@class,'addZ-index')]/descendant::button
当前节点之后
显示的所有节点
//td[@width='50%']/following::div[contains(text(),'行政区域')]
前节点之后
所有的兄弟(平级)节点
//div[@id="header"]/following-sibling::a
当前节点之前
显示的所有节点
//div[contains(@class,'container-types')]/preceding::div[@class="bg"]
前节点之前
所有的兄弟(平级)节点
//div[contains(@id,'el')]/preceding-sibling::span[@class="c-tips"]
使用通过子节点定位父节点
例://a[text()="数据库"]/../..
//a[text()="数据库"] 代表子节点
//a[text()="数据库"]/.. 代表含数据库这个的子节点的父节点
//a[text()="数据库"]/../.. 代表含数据库这个的子节点的爷爷节点
and
or
not
//a[contains(@href,'ki') and @target="_self"]
//a[contains(@href,'ki') or @target="_self"]
//a[contains(@href,'ki') not @target="_self"]