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入门视频一份】