Selenium+Python 自动化测试之XPath语法

前言

做过ui自动化测试或爬虫的同学都应该知道,XPath语法在定位HTML元素的中有着举足轻重的地位。今天我们就来盘点一下,我们在工作中常用的XPath语法。

1. 什么是XPath?

  • XPath使用路径表达式在XML文档中进行导航
  • XPath包含一个标准函数库
  • XPath是SXLT中的主要元素,是一个W3C标准

2. XPath语法

Selenium+Python 自动化测试之XPath语法_第1张图片

3. 代码演示

# -*- coding: utf-8 -*-

# 这里使用百度首页举例子

import time
from selenium import webdriver

driver = webdriver.Chrome()
# 设置窗口最大化
driver.maximize_window()
driver.get("https://www.baidu.com/")
# 设置全局等待,在find_element的时候有效
driver.implicitly_wait(10)

# 通过id定位,*匹配任何标签,中括号里支持匹配各种属性
driver.find_element_by_xpath('//*[@id="kw"]').send_keys('李二狗')
time.sleep(1)

# 指定标签
driver.find_element_by_xpath('//input[@class="s_ipt"]').send_keys('李二傻')
time.sleep(1)

# 其他属性
driver.find_element_by_xpath('//input[@autocomplete="off"]').send_keys('李三傻')
time.sleep(1)

# 组合,逻辑运算
driver.find_element_by_xpath('//input[@class="s_ipt" and @name="wd"]').send_keys('李四傻')
driver.find_element_by_xpath('//input[@id="kw" or @name="wd"]').send_keys('李五傻')
time.sleep(1)

# 文本属性,无@,点击“地图” 按钮
driver.find_element_by_xpath('//*[text()="地图"]').click()
time.sleep(1)

# 相对路径定位,点击“地图”按钮
driver.find_element_by_xpath('//div[@class="head_wrapper"]/div[3]/a[text()="地图"]').click()
time.sleep(2)

# 通过儿子找父亲,找到的是from标签
a = driver.find_element_by_xpath("//*[@id='su']/../..")
print(a.tag_name)
# 打印元素的class属性
print(a.get_attribute("class"))  

# 索引定位,点击“地图”按钮,这里的索引与python中不同,下标以1开始
driver.find_element_by_xpath('//*[@id="u1"]/a[3]').click()
time.sleep(2)

# 多个相同元素,不是一个父亲
# 此时通过XPath的索引已经是不行了,所以需要使用Python的索引来操作,下标从0开始
driver.get("http://top.baidu.com/?fr=mhd_card")
driver.find_elements_by_xpath('//ul[@id="hot-list"]/li/a[@class="list-title"]')[1].click()
time.sleep(1)

# 模糊匹配 contains
driver.find_element_by_xpath("//a[contains(text(),'图')]").click()
time.sleep(2)

# 关闭浏览器、关闭驱动
driver.quit()

你可能感兴趣的:(自动化测试,Selenium+Python,自动化之XPath语法)