0


Selenium(1)-webUI自动化环境部署,基本元素定位

web自动化测试环境部署

在正式开启自动化测试之前,我们需要给自动化提供完备的测试环境,需要我们搭建一套完整的运行环境,以便能模拟用户的行为。
首先,我们需要安装python编译器,一个编写代码的工具,如pycharm,完成这两个操作后,我们在进行以下的步骤:
1、安装/卸载selenium:
作用:按照selenium模块到python中,selenium可以给我提供丰富的方法和属性,利于我们在编写代码时可直接导入并调用。
安装步骤:
在命令行窗口(cmd窗口) :输入如下命令
安装selenium命令:

pip install selenium

卸载selenium命令:

pip uninstall selenium

查看是否安装成功:

pip show selenium

或者

pip list

(查看已安装的应用)
2、下载安装浏览器驱动 :
在进行自动化测试代码编写时,为了使用代码控制浏览器,我们需要借助浏览器的驱动来完成这个过程,如果没有浏览器驱动,我们则不能正常的运行web应用软件。

获取谷歌浏览器的驱动地址:http://chromedriver.storage.googleapis.com/index.html

下载驱动器时,应该下载与本地浏览器版本最接近的版本,如下:浏览器驱动
注意:下载时,下载32位的可以兼容64位的,但是64不能兼容32位的,为了方便,最好下载32位的驱动器
3、安装浏览器驱动
下载后的文件解压后,得到chromedriver.exe文件,放到与python.exe同一个目录下即可。

入行自动化三行代码

编写web自动化测试的步骤
1、导入selenium 包
2、实例化浏览器对象(例如Google,火狐等)
3、打开待测试的网站URL
4、实施自动化测试内容–非必须
5、关闭官网–非必须

"""
web 自动化基本代码:打开并关闭百度网页
"""
# 1、导包
from time import sleep
from selenium import webdriver

# 2、实例化浏览器对象:类名()
driver = webdriver.Chrome()
# 3、打开网页包含协议头
driver.get('https://www.baidu.com/')
# 4、实施操作
ele = deiver.find_element(‘id’,'kw').click() # 点击操作
# 5、关闭网页
driver.quit()

六种基础定位方法(单个元素定位)

image.png

1、ID属性定位法: find_element_by_id(‘ID名称’)
2、name属性定位法:find_element_by_name (‘name的值’)
3、class name属性定位法:find_element_by_class_name(‘class的值’)
4、tag name定位法:find_element_by_tag_name(“标签名”)
5、link text 定位法:find_element_by_link_text(‘文本内容’).click()–超链接精准匹配
6、partial link text 定位法:find_element_by_partial_link_text(‘模糊匹配’).click()–超链接模糊匹配

1、ID属性定位法:

语法:

find_element_by_id('ID名称')

说明:一般来说id是唯一的,存在id优先选择使用该属于定位
实际应用举例:

from selenium import webdriver
driver = webdriver.Chrome()
driver.get('https://www.baidu.com/')
driver.find_element_by_id('kw').send_keys('如何使用selenium实现自动化测试?')
driver.find_element_by_id('su').click()

2、name属性定位法:

语法:

driver.find_element_by_name('name的值')

说明:name属于在页面不一定是唯一的,因此在使用该方法时,应该确保name唯一,如果不唯一,默认为第一个name(如果刚好所需的为第一个,则可用,若非第一个,可使用其他方法定位)
实际应用举例:

# 导包
from time import sleep
from selenium import webdriver
# 实例化浏览器
driver = webdriver.Chrome()
# 打开网址
driver.get('https://www.baidu.com/')
# 需求
ele = driver.find_element('name', 'wd') # name是唯一的,可用/name为页面第一个元素
ele.send_keys('易烊千玺')
# 时间轴看效果
sleep(2)
# 关闭页面
driver.quit()

3、class name属性定位法:

语法:

driver.find_element_by_class_name

说明:不允许使用复合类名(多值,只需要定位其中一个),使用该属性时,元素必须要有class属性(方法名是class_name ,但是我们找的是class属性)class定位
实际应用举例:

# 导包
from time import sleep
from selenium import webdriver
# 实例化浏览器
driver = webdriver.Chrome()
# 打开网址
driver.get('https://www.baidu.com/')
# 需求
ele = driver.find_element('class', 's_ipt_wr ')  # class为多值,取一个值即可
ele.click()
# 时间轴看效果
sleep(2)
# 关闭页面
driver.quit()

4、tag name定位法:

语法:

driver.find_element_by_tag_name("标签名")

说明:因为重复的很多很多,几乎不用,必须确认该标签具有唯一性,才可以使用,如果页面存在很多相同的标签,默认返回第一个
实际应用举例:

# 导包
from time import sleep
from selenium import webdriver
# 实例化浏览器
driver = webdriver.Chrome()
# 打开网址
driver.get('https://www.baidu.com/')
# 需求
ele = driver.find_element('tag name', 'input')  # input标签
ele.send_keys('admin')
# 时间轴看效果
sleep(2)
# 关闭页面
driver.quit()

5、link text 定位法:

语法:

driver.find_element_by_link_text('文本内容').click()

说明:a标签的文本定位(只能a标签),且需要输入超链接的全部⽂;一般与click方法连用:元素对象 .click()本信息
实际应用举例:

# 导包
from time import sleep
from selenium import webdriver

# 实例化浏览器对象
driver = webdriver.Chrome()
# 打开网址url
driver.get('https://www.baidu.com/')
# 需求
username = driver.find_element_by_link_text('新闻')
username .click()
sleep(3)
# 关闭网页
driver.quit()

6、partial link text 定位法:

语法:

driver.find_element_by_partial_link_text('模糊匹配').click()

说明:a标签的部分文本定位(只能a标签)
实际应用举例:与 link text 定位法一样,不过只需要写该链接的部门文本即可

# 导包
from time import sleep
from selenium import webdriver

# 实例化浏览器对象
driver = webdriver.Chrome()
# 打开网址url
driver.get('https://www.baidu.com/')
# 需求
username = driver.find_element_by_link_text('新')
username .click()
sleep(3)
# 关闭网页
driver.quit()

7、定位一组元素find_elements

driver.find_elements_by_xxx:与driver.find_element_by_xxx的方法一致,不过它返回的结果是一组数据,返回数据类型是列表,是多个元素对象


本文转载自: https://blog.csdn.net/qq_41389678/article/details/142555340
版权归原作者 媛媛要加油呀 所有, 如有侵权,请联系我们删除。

“Selenium(1)-webUI自动化环境部署,基本元素定位”的评论:

还没有评论