selenium自动化测试:xpath八种定位方式!

1123 篇文章 44 订阅
828 篇文章 2 订阅

selenium自动化测试:5.xpath八种定位方式

01、前言

如果可以的话,请先关注(专栏和账号),然后点赞和收藏,最后学习和进步。你的支持是我继续写下去的最大动力,个人定当倾囊而送,不负众望。谢谢!!!

1.前提

基于win10专业版64位系统+64位jdk1.8+64位python3.6.5+社区版pycharm2018.1.3+unittest+selenium3.141.0。

2.xpath八种定位方式

xpath:即xml路径语言,通常用来在html或xml中查找元素。

掌握了xpath八种定位方式能干啥?既不能上天也不能遁地,但能解决你在selenium自动化测试定位元素时百分之99.999999999......的元素都可以定位得到。

下来看下xpath的基本语法:

# /:从根节点选取
# //:从非根节点选取
# *:任意节点选取
# @:根据属性
# text():根据链接文本
# and:关联属性或链接文本
# []:可以放置下标、属性和链接文本
# .:选取当前节点
# ..:选取当前节点的父节点
# contains:包含,用于模糊匹配

说明:xpath涉及到的东西还有很多,这里仅教会大家做自动化测试时,会灵活书写xpath定位语句即可。

1)全路径:不推荐

from time import sleep
from selenium import webdriver
dr = webdriver.Chrome()
dr.maximize_window()
dr.get('https://www.baidu.com/')
dr.find_element_by_xpath("/html/body/div/div/div[2]/a[3]").click()#全路径定位,不推荐
sleep(1)
dr.close()

2)单属性

from time import sleep
from selenium import webdriver
dr = webdriver.Chrome()
dr.maximize_window()
dr.get('https://www.baidu.com/')
dr.find_element_by_xpath("//a[@name='tj_trhao123']").click()#单属性定位
sleep(1)
dr.close()

3)多属性

from time import sleep
from selenium import webdriver
dr = webdriver.Chrome()
dr.maximize_window()
dr.get('https://www.baidu.com/')
dr.find_element_by_xpath("//a[@name='tj_trhao123' and @class='mnav']").click()#多属性定位
sleep(1)
dr.close()

4)父属性

from time import sleep
from selenium import webdriver
dr = webdriver.Chrome()
dr.maximize_window()
dr.get('https://www.baidu.com/')
dr.find_element_by_xpath("//div[@id='u1']/a[@name='tj_trhao123']").click()#父属性定位
sleep(1)
dr.close()

5)下标

from time import sleep
from selenium import webdriver
dr = webdriver.Chrome()
dr.maximize_window()
dr.get('https://www.baidu.com/')
dr.find_element_by_xpath("//a[@class='mnav'][2]").click()#下标定位
sleep(1)
dr.close()

6).和..

from time import sleep
from selenium import webdriver
dr = webdriver.Chrome()
dr.maximize_window()
dr.get('https://www.baidu.com/')
dr.find_element_by_xpath("//a[@class='mnav'][2]/.").click()#.和..定位
sleep(1)
dr.close()

7)链接文本

from time import sleep
from selenium import webdriver
dr = webdriver.Chrome()
dr.maximize_window()
dr.get('https://www.baidu.com/')
dr.find_element_by_xpath("//a[text()='hao123']").click()#链接文本定位
sleep(1)
dr.close()

8)模糊匹配

from time import sleep
from selenium import webdriver
dr = webdriver.Chrome()
dr.maximize_window()
dr.get('https://www.baidu.com/')
# dr.find_element_by_xpath("//a[contains(@name,'hao')]").click()#模糊匹配定位
dr.find_element_by_xpath("//a[contains(text(),'hao')]").click()#模糊匹配定位
sleep(1)
dr.close()

注:xpath八种定位方式,除了第一种全路径定位方式不推荐外,其它几种定位方式,你觉得哪个方便就用哪个好了。

最后感谢每一个认真阅读我文章的人,看着粉丝一路的上涨和关注,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走!

软件测试面试文档

我们学习必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有字节大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。
 

在这里插入图片描述

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值