文章目录
- [0. 八大定位方法](#0. 八大定位方法)
- [1. id](#1. id)
- [2. name](#2. name)
- [3. xpath](#3. xpath)
- [4. css_selector](#4. css_selector)
0. 八大定位方法
当实现测试自动化,编写测试用例时,首先需要在web界面找到对应元素位置,而Selenium提供了一套对应的API,被封装在WebDriver类中。如下图,分别对应八种定位方法。下面再详细介绍。
- By.ID:通过元素的 ID 查找。
- By.NAME:通过元素的 name 属性查找。
- By.XPATH:通过 XPath 表达式查找。
- By.LINK_TEXT:通过链接文本查找。
- By.PARTIAL_LINK_TEXT:通过链接的部分文本查找。
- By.TAG_NAME:通过元素的标签名查找。
- By.CLASS_NAME:通过元素的类名查找。
By.CSS_SELECTOR:通过 CSS 选择器查找。
1. id
从浏览器获得元素ID
1.F12打开当前页面控制台
2.可以打开元素,进行查找,也可以点击左上角箭头,再点击web页面上需要的元素,如图
python
from selenium import webdriver
from time import sleep
from selenium.webdriver.common.by import By
driver = webdriver.Chrome() # 创建Chrome浏览器实例,可以通过实例操控浏览器
driver.get('http://www.baidu.com') # get可以打开一个url
sleep(2)
# find_element是webdriver中的方法,用来查找网页元素
# By.ID是一个定位器,ID就是通过ID的方法定位,'kw'就是元素id
# send_keys也是以恶搞方法,可以用例输入内容
driver.find_element(By.ID, 'kw').send_keys('selenium')
sleep(2)
# click是webdriver中的方法,表示点击事件
driver.find_element(By.ID, 'su').click()
sleep(2)
# 退出
driver.quit()
2. name
除了id,还可以使用name标签,使用起来和name一样,但是需要注意web页面元素name理论上不要重复,但是是可以重复的,所以获得是当前页面的第一个name标签元素。
python
from selenium import webdriver
from time import sleep
from selenium.webdriver.common.by import By
driver = webdriver.Chrome() # 创建Chrome浏览器实例,可以通过实例操控浏览器
driver.get('http://www.baidu.com') # get可以打开一个url
sleep(2)
# find_element是webdriver中的方法,用来查找网页元素
# By.NAME是一个定位器,NAME就是通过NAME的方法定位,'wd'就是元素name
# send_keys也是以恶搞方法,可以用例输入内容
driver.find_element(By.NAME, 'wd').send_keys('selenium')
sleep(2)
# click是webdriver中的方法,表示点击事件
driver.find_element(By.ID, 'su').click()
sleep(2)
# 退出
driver.quit()
3. xpath
xpath是通过路径的方式获得元素的,一般通过id和name的方式获得元素位置,这是非常简单的,但有时我们无法获得id和name,就可以通过xpath,xpath基本上可以获得任何元素的精准位置,但是获得的速度相对来说比较慢,而且使用xpath获得元素位置,当页面进行修改,元素位置发生改变,我们前面的脚本有时就需要修改,所以页面如果频繁较大修改,可以减少xpath的使用。
如上图,我们可以通过双击元素,点击'复制',再点击'复制xpath',这里是一个相对路径,下面还有一个完整xpath,这个是绝对路径,绝对路径对页面结构依赖性比较高,定位元素速度不如相对路径。
python
from selenium import webdriver
from time import sleep
from selenium.webdriver.common.by import By
driver = webdriver.Chrome() # 创建Chrome浏览器实例,可以通过实例操控浏览器
driver.get('http://www.baidu.com') # get可以打开一个url
sleep(2)
# find_element是webdriver中的方法,用来查找网页元素
# By.XPATH是一个定位器,XPATH就是通过XPATH的方法定位,'//*[@id="kw'就是元素xpath
# send_keys也是以恶搞方法,可以用例输入内容
driver.find_element(By.XPATH, '//*[@id="kw"]').send_keys('selenium')
sleep(2)
# click是webdriver中的方法,表示点击事件
driver.find_element(By.ID, 'su').click()
sleep(2)
# 退出
driver.quit()
4. css_selector
除了上面三种,还可以通过css选择器进行定位,css选择器的语法比较简洁,使用起来速度比xpath快,可以通过id、name、class等进行定位。例如:id选择器:使用#符号后跟元素的ID属性值来选择元素,如#myElement;类选择器:使用.符号后跟元素的class属性值来选择元素,如.myClass。
当然,还有个简单的方法,直接从浏览器上进行复制,点击【复制selector】:
python
from selenium import webdriver
from time import sleep
from selenium.webdriver.common.by import By
driver = webdriver.Chrome() # 创建Chrome浏览器实例,可以通过实例操控浏览器
driver.get('http://www.baidu.com') # get可以打开一个url
sleep(2)
# find_element是webdriver中的方法,用来查找网页元素
# By.CSS_SELECTOR是一个定位器
# send_keys也是以恶搞方法,可以用例输入内容
driver.find_element(By.CSS_SELECTOR, '#kw').send_keys('selenium')
sleep(2)
# click是webdriver中的方法,表示点击事件
driver.find_element(By.ID, 'su').click()
sleep(2)
# 退出
driver.quit()
以上重点介绍个四种,其实每种使用起来基本上相同,就是各有优劣而已。其他四种就和它们的名字相同,大家可以自行尝试一下。