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()

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

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属性)

实际应用举例:

复制代码
# 导包
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()

语法: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()

语法: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的方法一致,不过它返回的结果是一组数据,返回数据类型是列表,是多个元素对象

相关推荐
半路_出家ren1 小时前
流量抓取工具(wireshark)
网络·网络协议·测试工具·网络安全·wireshark·流量抓取工具
猿周LV2 小时前
JMeter 安装及使用 [软件测试工具]
java·测试工具·jmeter·单元测试·压力测试
工头阿乐4 小时前
Appium自动化开发环境搭建
运维·appium·自动化
西柚小萌新16 小时前
【Python爬虫基础篇】--4.Selenium入门详细教程
爬虫·python·selenium
夸克App17 小时前
实现营销投放全流程自动化 超级汇川推出信息流智能投放产品“AI智投“
运维·人工智能·自动化
Rainbond云原生17 小时前
83k Star!n8n 让 AI 驱动的工作流自动化触手可及
运维·人工智能·自动化
YONG823_API17 小时前
深度探究获取淘宝商品数据的途径|API接口|批量自动化采集商品数据
java·前端·自动化
木觞清17 小时前
深度对比评测:n8n vs Coze(扣子) vs Dify - 自动化工作流工具全解析
运维·自动化
电商数据girl17 小时前
产品经理对于电商接口的梳理||电商接口文档梳理与接入
大数据·数据库·python·自动化·产品经理
??? Meggie20 小时前
Selenium 怎么加入代理IP,以及怎么检测爬虫运行的时候,是否用了代理IP?
爬虫·tcp/ip·selenium