web自动化第二章-XPath、 CSS定位

目标
1. 掌握XPath定位策略
2. 掌握CSS定位策略
为什么要学习XPath、 CSS定位?
1. 如果要定位的元素没有id、 name、 class属性, 该如何进行定位?
2. 如果通过name、 class、 tag_name无法定位到唯一的元素, 该如何进行定位?
示例:
<input type="submit" value="提交" />

1. 什么是XPath?


1. XPath即为XML Path的简称, 它是一门在 XML 文档中查找元素信息的语言。
2. HTML可以看做是XML的一种实现, 所以Selenium用户可以使用这种强大的语言在Web应用中定位元素。
XML: 一种标记语言, 用于数据的存储和传递。 后缀.xml结尾
 

<?xml version="1.0" encoding="UTF-8" ?>
<node>
<db id="db" desc="三条边的长度都一样">
<b1>3</b1>
<b2>3</b2>
<b3>3</b3>
<expect>等边三角形</expect>
</db>
<dy>
<b1>4</b1>
<b2>4</b2>
<b3>5</b3>
<expect>等腰三角形</expect>
</dy>
</node>

XPath定位方式之所以强大, 是因为它有非常灵活的定位策略


2. XPath定位策略(方式)


1. 路径-定位
2. 利用元素属性-定位
3. 属性与逻辑结合-定位
4. 层级与属性结合-定位

 

XPath定位方法
element = driver.find_element_by_xpath(xpath)

 

2.1 路径定位(绝对路径、 相对路径)
绝对路径: 从最外层元素到指定元素之间所有经过元素层级的路径
1). 绝对路径以/html根节点开始, 使用/来分隔元素层级;
如: /html/body/div/fieldset/p[1]/input
2). 绝对路径对页面结构要求比较严格, 不建议使用
相对路径: 匹配任意层级的元素, 不限制元素的位置
1). 相对路径以//开始
2). 格式: //input 或者 //*
 

层级关系:

<body>
<form action="">
	<div id="zc">
		<fieldset>
		<legend>注册用户A</legend>
			<p id="p1">
				<label for="userA">账号A</label>
		 		<input type="textA" name="userA" id="userA" placeholder="账号A" required="" value="">
"""
    需求:
        1. 使用绝对路径定位 用户名 输入 admin
        2. 暂停2秒钟
        3. 使用相对路径定位 密码框 输入 123

    方法:
        driver.find_element_by_xpath()
"""

# 导包
import time

from selenium import webdriver
from time import sleep
# 获取 火狐浏览器对象
#driver = webdriver.Firefox()

# 获取 谷歌浏览器对象
driver = webdriver.Chrome()

# 获取 Ie
# driver = webdriver.Ie()
# 打开 注册A.html
url = r"E:\Python\测试资料\8天web自动化讲义\素材\注册A.html"
driver.get(url)

# 使用绝对路径定位 用户名 admin
driver.find_element_by_xpath("/html/body/form/div/fieldset/p[1]/input").send_keys("admin")
time.sleep(3)
driver.quit()

2.2 利用元素属性
说明: 通过使用元素的属性信息来定位元素
格式: //input[@id='userA'] 或者 //*[@id='userA']
练习
需求: 打开注册A.html页面, 完成以下操作
1).利用元素的属性信息精确定位用户名输入框, 并输入: admin
 

"""
    需求:
        1. 使用绝对路径定位 用户名 输入 admin
        2. 暂停2秒钟
        3. 使用相对路径定位 密码框 输入 123

    方法:
        driver.find_element_by_xpath()
"""

# 导包
import time

from selenium import webdriver
from time import sleep
# 获取 火狐浏览器对象
#driver = webdriver.Firefox()

# 获取 谷歌浏览器对象
driver = webdriver.Chrome()

# 获取 Ie
# driver = webdriver.Ie()
# 打开 注册A.html
url = r"E:\Python\测试资料\8天web自动化讲义\素材\注册A.html"
driver.get(url)

# 使用绝对路径定位 用户名 admin
#driver.find_element_by_xpath("/html/body/form/div/fieldset/p[1]/input").send_keys("admin")
driver.find_element_by_xpath("//input[@id='userA']").send_keys("admin")
time.sleep(3)
driver.find_element_by_xpath("//input[@id='userA']").send_keys("admin1")

time.sleep(3)
driver.quit()

2.3 属性与逻辑结合
说明: 解决元素之间个相同属性重名问题
格式: //*[@name='tel' and @class='tel']
练习
需求: 打开注册A.html页面, 完成以下操作
1).使用属性与逻辑结合定位策略, 在test1对应的输入框里输入: admin
 

需求: 打开注册A.html页面, 完成以下操作
1).使用属性与逻辑结合定位策略, 在test1对应的输入框里输入: admin
 

<div id="zc">
		<fieldset>
		<legend>注册用户A</legend>
			<p id="p1">
				<label for="userA">账号A</label>
		 		<input type="textA" name="userA" id="userA" placeholder="账号A" required="" value="">			
			</p>
	 		<p>
				<label for="password">密码A</label>		
				<input type="password" name="passwordA" id="passwordA" placeholder="密码A" value="">
	 		</p>
			<p>
				<label for="telA">电话号码A</label>
				<input type="telA" name="telA" id="telA" placeholder="电话A" class="telA" value="">				
			</p>

2.4 层级与属性结合
说明: 如果通过元素自身的信息不方便直接定位到该元素, 则可以先定位到其父级元素, 然后再找到该元素
格式: //*[@id='p1']/input
需求: 打开注册A.html页面, 完成以下操作
1).使用层级与属性结合定位策略, 在test1对应的输入框里输入: admin
 

# 使用层级结合属性 定位用户名:
# driver.find_element_by_xpath("//p[@id='p1']/input").send_keys("admin")
driver.find_element_by_xpath("//*[@name='telA' and @class='telA']").send_keys("admin")
time.sleep(3)
driver.quit()

2.5 XPath-延伸
//*[text()="xxx"] 文本内容是xxx的元素
//*[contains(@attribute,'xxx')] 属性中含有xxx的元素
//*[starts-with(@attribute,'xxx')] 属性以xxx开头的元素

2.6 XPath-总结
1. XPath定位策略有哪些?
3. CSS定位
3.1 什么是CSS定位?
12

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
XPath是一种XML文档的定位方法,也可以用于HTML文档的定位,Selenium中也可以使用XPath定位网页元素。下面是使用XPath定位元素的详细步骤: 1. 打开浏览器并访问网页: ```python from selenium import webdriver driver = webdriver.Chrome() driver.get("http://www.example.com") ``` 2. 使用XPath定位元素: ```python # 通过元素id定位 element = driver.find_element_by_xpath('//*[@id="element_id"]') # 通过元素name定位 element = driver.find_element_by_xpath('//*[@name="element_name"]') # 通过元素class定位 element = driver.find_element_by_xpath('//*[@class="element_class"]') # 通过元素标签名定位 element = driver.find_element_by_xpath('//tag_name') # 通过元素属性定位 element = driver.find_element_by_xpath('//*[@attribute_name="attribute_value"]') # 通过元素文本内容定位 element = driver.find_element_by_xpath('//*[text()="text_content"]') # 通过元素部分文本内容定位 element = driver.find_element_by_xpath('//*[contains(text(), "text_content")]') ``` 3. 对元素进行操作: ```python # 输入文本 element.send_keys("text_input") # 点击元素 element.click() # 获取元素文本 print(element.text) # 获取元素属性值 print(element.get_attribute("attribute_name")) ``` 注意事项: - XPath定位需要用到浏览器的开发者工具,在开发者工具中可以查看元素XPath路径。 - XPath路径中的引号需要用不同类型的引号包裹,例如在单引号内使用双引号包裹。 - 如果XPath路径中包含斜杠(/),则需要使用双斜杠(//)或者使用单引号包裹整个XPath路径。 - 在XPath路径中没有找到元素时,会抛出NoSuchElementException异常。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值