您当前的位置:首页 > 计算机 > 编程开发 > Python

Selenium成长之路-11简单对象定位之XPATH方法

时间:03-20来源:作者:点击数:

XPath是一种在HTML文档中定位元素的语言。因为 HTML 可以看做 XML 的一种实现,所以 selenium 用 户可是使用这种强大语言在 web 应用中定位元素。

XPath基于XML的树状结构,提供在数据结构树中找寻节点的能力,XPath 很快的被开发者采用来当作小型查询语言。

XPath的使用,需要在Firefox浏览器先安装FireBug插件,建议使用Firefox浏览器(建议版本:57以前版本),因为57以后的版本,不支持FireBug插件了,也可能是新版本我个人使用的不太习惯。

安装完FireBug插件后,我们就在百度首页使用xpath进行元素定位

我们定位的是"百度一下"搜索按钮,在FirePath中可以看到,xpath的写法是://*[@id='su']

如果我们定位的元素很长,怎么办呢?

如下图,我们要定位百度新闻页面的一段标题:

这样xpath路径直接写成:driver.find_element(By.XPATH,"//*[@id='pane-news']/div/ul/li[5]/strong/a") 是没有问题的

但是,在实际测试过程中,我们并不喜欢用这么长的路径来定位,这个时候,我们就可以使用contains()或者text()方法来定位;

contains()方法:driver.find_element(By.XPATH,"//*/a[contains(@href,'china.chinadaily')]")

text()方法:driver.find_element(By.XPATH,"//*[@class = 'lavalamp-item']/a[text()= '体育']")

这样就很简单了。

附上一段代码:

# coding = utf-8
from selenium import  webdriver
import time
from selenium.webdriver.common.by import By

driver = webdriver.Chrome()
url = 'http://news.baidu.com'
driver.get(url)

# 增加一个判断
try:
    #直接从firebug复制出来的路径
    # driver.find_element(By.XPATH,"//*[@id='pane-news']/div/ul/li[5]/strong/a")
    #使用contains()方法定位
    # driver.find_element(By.XPATH,"//*/a[contains(@href,'china.chinadaily')]")
    #使用text()方法定位
    driver.find_element(By.XPATH,"//*[@class='lavalamp-item']/a[text()='体育']")
    print("test pass")

except Exception as e:
    print("test failed",format(e))


time.sleep(5)
driver.quit()

总结一下Xpath的定位方法:

1.绝对路径定位:find_element_by_xpath("/html/body/div[2]/form/span/input")

2.相对路径定位:find_element_by_xpath("//input[@id=’input’]") #通过自身的 id 属性定位

3.布尔逻辑运算://div[@id='hd' or @name='q']

4.模糊定位(contains)://*/a[contains(@href,'china.chinadaily')]

5.再就是非常方便的,直接使用firebug,定位路径直接copy出来就可以了

xpath在实际的测试过程中运用很广泛,所以学习selenium的小伙伴,有必要掌握xpath的元素定位方法哦~~

方便获取更多学习、工作、生活信息请关注本站微信公众号城东书院 微信服务号城东书院 微信订阅号
推荐内容
相关内容
栏目更新
栏目热门