Python+Selenium自动化测试详细教程

news2024/12/23 14:58:22

前言

  • Python+Selenium 来实现的web端自动化, 以下演示会用到禅道、百度和自己编写的html.

一、准备工作

1、安装

  • 安装Python 3
  • 安装selenium库,命令:pip install selenium
  • 搭建禅道环境

2、导入浏览器驱动

selenium操作不同的浏览器,需要下载不同浏览器的驱动


  • Firefox 浏览器驱动: 浏览器驱动下载 webdriver.Chrome()
  • Chrome浏览器驱动:浏览器驱动下载 webdriver.Firefox()
  • IE浏览器驱动:浏览器驱动下载 webdriver.Ie()
  • Edge浏览器驱动:浏览器驱动下载 webdriver.Edge()

以chrome浏览器为例:
1、进入到下载页面,找到符合自己浏览器版本的驱动
2、下载好了之后,右键解压到当前文件夹
3、将得到的chromedriver.exe放到Python的安装目录
在这里插入图片描述

二、使用

from selenium import webdriver
from selenium.webdriver.common.by import By
import time


class Zen_Tao:

    def __init__(self):
        # 初始化一个chrome浏览器(驱动谷歌浏览器时,直接使用webdriver.Chrome()可能会报错,建议使用一下方法)
        options = webdriver.ChromeOptions()
        options.add_experimental_option('excludeSwitches', ['enable-logging'])
        self.drive = webdriver.Chrome(options=options)
        # 最大化窗口
        self.drive.maximize_window()
        # 隐式等待,设置最大的等待时长,只对查找元素(find_elementXXX)生效
        self.drive.implicitly_wait(2)

    def log_on(self):
        '''代码执行'''
        # 通过get()方法打开网页
        self.drive.get('http://192.168.100.210/zentao/')

    def sign_out(self):
        '''退出浏览器'''
        self.drive.close()  # 关闭浏览器
        self.drive.quit()  # 关闭浏览器并且关闭驱动


if __name__ == "__main__":
    run = Zen_Tao()
    run.log_on()
    run.sign_out()

1、元素定位方法

  • 禅道登陆演示
    在这里插入图片描述
图一

在这里插入图片描述

图二

  • 单属性查找
    def log_on(self):
        '''代码执行'''
        # 通过get()方法打开网页
        self.drive.get('http://192.168.100.210/zentao/')

        # 1.用 id 属性定位查找
        self.drive.find_element(By.ID, "account")

        # 2.用 name 属性定位查找
        self.drive.find_element(By.NAME, "account")

        # 3.用 class 属性定位查找
        self.drive.find_element(By.CLASS_NAME, "form-control")

        # 4.用 xpath 属性定位查找
        self.drive.find_element(By.XPATH, '//*[@id="account"]')

        # 5.具有给定标签名称的第一个元素将被返回
        self.drive.find_element(By.TAG_NAME, "input")

        # 6.用 css 属性定位查找
        # 方法一[标签名]
        self.drive.find_element(By.CSS_SELECTOR, 'input')
        # 方法二[id], #代表id
        self.drive.find_element(By.CSS_SELECTOR, '#account')
        # 方法三[class], .代表class
        self.drive.find_element(By.CSS_SELECTOR, '.form-control')
        # 方法四[其他属性]
        self.drive.find_element(By.CSS_SELECTOR, '[name="account"]')

        # 7.链接文本值与位置匹配的第一个元素将被返回
        # (通过标签对之间的文本进行定位)
        self.drive.find_element(By.LINK_TEXT, "忘记密码")

        # 8.具有部分链接文本值与位置匹配的第一个元素将被返回
        # (partial link其实是对link的一个扩展,因为有些时候链接文本很长,这时候就可以使用其中的一部分来进行定位)
        self.drive.find_element(By.PARTIAL_LINK_TEXT, "忘记")
  • 组合属性查询
    def log_on(self):
        '''代码执行'''
        # 1.通过get()方法打开网页
        self.drive.get('http://192.168.100.210/zentao/')

        # 2.标签名和id属性值组合定位
        self.drive.find_element(By.CSS_SELECTOR, 'input#account')

        # 3.标签名和class属性值组合定位
        self.drive.find_element(By.CSS_SELECTOR, 'input.form-control')

        # 4.标签名和属性(含属性值)组合定位
        self.drive.find_element(By.CSS_SELECTOR, 'input[name="account"]')

        # 5.多个属性组合定位
        self.drive.find_element(By.CSS_SELECTOR, '[class="form-control"][name="account"]')
  • 层级查询
    在这里插入图片描述
图三
    def log_on(self):
        '''代码执行'''
        # 通过get()方法打开网页
        self.drive.get('http://192.168.100.210/zentao/')

        # 1.查询元素时,我们也可以先查询父级,然后再查询子级,父级和子级用空格隔开,如上图所示(div - table - input)
        self.drive.find_element(By.CSS_SELECTOR, '.col-8 [class="table table-form"] #account')

  • 我们在进行元素定位时,获取到的元素一定是唯一的或第一个。查看是否唯一我们可以按CTRL+F搜索,如下:

在这里插入图片描述

2、输入、清空、点击操作

    def log_on(self):
        '''代码执行'''
        # 通过get()方法打开网页
        self.drive.get('http://192.168.100.210/zentao/')

        # 输入:send_keys()
        self.drive.find_element(By.CSS_SELECTOR, '#account').send_keys("admin")

        # 清空: clear()
        self.drive.find_element(By.CSS_SELECTOR, '#account').clear()

        # 单机操作(相当于鼠标点击):click()
        self.drive.find_element(By.CSS_SELECTOR, '.form-actions #submit').click()

3、回车键操作

# 点击登录按钮,一般情况下,使用click()进行点击
# 有些时候也可以使用submit()代替click(),相当于敲回车
    def log_on(self):
        '''代码执行'''
        # 通过get()方法打开网页
        self.drive.get('https://www.baidu.com/')

        # 输入内容,点击百度一下
        self.drive.find_element(By.CSS_SELECTOR, '[class="s_ipt"]').send_keys("软件测试")
        # 回车操作(相当于按回车键):submit()
        self.drive.find_element(By.CSS_SELECTOR, '[id="su"]').submit()

4、获取元素内容

-Text获取元素内容

在这里插入图片描述

# text 获取元素内容
text = self.drive.find_element(By.CSS_SELECTOR, '.form-actions a').text
print(text)

# 结果:忘记密码
  • 如果使用Text获取元素内容时,返回的是空值,但未报错,这个时候我们需要使用get_attribute(‘innerText’)获取元素的内容
    在这里插入图片描述
# 获取元素内容
get = self.drive.find_element(By.CSS_SELECTOR, '#loginPanel h2').get_attribute('innerText')
print(get)

# 结果:易软天创项目管理系统

5、获取元素属性的值

  • 禅道登陆演示

在这里插入图片描述

# 获取属性的值
get = self.drive.find_element(By.CSS_SELECTOR, '[id="keepLoginon"]').get_attribute('title')
print(get)

# 结果:保持登录

6、元素判断

  • 没有演示环境,就自己写一个html页面

在页面中显示元素:
在这里插入图片描述

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>演示数据</title>
</head>
<body>
      <form>
            <input type="text" value="用户名" id="account"><br>
			<input type="password" value="密码" id="password"><br>
        </form>
</body>
</html>

在页面中不显示元素:
在这里插入图片描述

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>演示数据</title>
</head>
<body>
      <form>
          <input style="visibility: hidden;" type="text" value="用户名" id="account"><br>
	      <input type="password" value="密码" id="password"><br>
        </form>
</body>
</html>

禁用输入框:
在这里插入图片描述

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>演示数据</title>
</head>
<body>
      <form>
          <input disabled="disabled" type="text" value="用户名" id="account"><br>
	      <input type="password" value="密码" id="password"><br>
      </form>
</body>
</html>

1、is_displayed()

1、is_displayed():判断元素是否存在,结果是真或假
1-1显示元素,在HTML里,在页面也显示,返回True1-2隐藏元素,在HTML里,不在页面显示,返回Flase
1-3不在HTML里,不存在这个元素,会报错

# 判断输入框是否在页面中显示
drive = self.drive.find_element(By.CSS_SELECTOR, '#account').is_displayed()
print(f"元素是否显示:{drive}")

2、is_enabled()

is_enabled():判断是否可用
# 判断输入框是否可以输入
drive = self.drive.find_element(By.CSS_SELECTOR, '#account').is_enabled()
print(f"输入框是否可以输入:{drive}")

3、is_selected()

  • 禅道登陆页面演示
is_selected():判断是否选中,一般用于复选框或单选框的选中判断
# 勾选保持登陆操作
# self.drive.find_element(By.CSS_SELECTOR, '[name="keepLogin[]"]').click()
drive = self.drive.find_element(By.CSS_SELECTOR, '[name="keepLogin[]"]').is_selected()
if drive:
	print(f"已勾选:{drive}")
else:
	print(f"未勾选:{drive}")


7、iframe&frame切换

说明:在html语法中,frame 元素或者iframe元素的内部会包含一个被嵌入的另一份html文档,这个时候如果我们需要操作iframe内的文档,就需要先切换到被嵌入的文档中,才可以进行操作。

  • 禅道登陆后演示
    在这里插入图片描述
    在这里插入图片描述
    1.先定位到需要切换的文档 — iframe&frame
    2.切换文档(切到frame中):switch_to.frame()
    3.从子frame切回到父frame:switch_to.parent_frame()
    4.切换到最外层文档(从frame中切回主文档):switch_to.default_content()
    def log_on(self):
        '''代码执行'''
        # 通过get()方法打开网页
        self.drive.get('http://192.168.100.210/zentao/')
        # 登陆禅道
        self.drive.find_element(By.CSS_SELECTOR, '[id="account"]').send_keys("admin")
        time.sleep(1)
        self.drive.find_element(By.CSS_SELECTOR, '[name="password"').send_keys("123456")
        time.sleep(1)
        self.drive.find_element(By.CSS_SELECTOR, '[id="submit"]').click()
        time.sleep(1)
        # 切换方法如下:
        # 方法一
        # iframe = self.drive.find_elements_by_tag_name("iframe")[0]
        # self.drive.switch_to.frame(iframe)

        # 方法二
        # self.drive.switch_to.frame(0)

        # 方法三
        iframe = self.drive.find_element(By.CSS_SELECTOR, '#appIframe-my')
        self.drive.switch_to.frame(iframe)
        time.sleep(1)
        # 点击联系人
        self.drive.find_element(By.XPATH, '//*[@id="navbar"]/ul/li[5]/a').click()
        
        # 切换到最外层表单
        self.drive.switch_to.default_content()
        time.sleep(1)
        # 点击项目
        self.drive.find_element(By.CSS_SELECTOR, '#menu [data-app="project"]').click()

8、鼠标悬停

  • 禅道登陆界面,选择语言
    在这里插入图片描述
  • 鼠标悬停需要导入:from selenium.webdriver import ActionChains
    def log_on(self):
        '''代码执行'''
        # 通过get()方法打开网页
        self.drive.get('http://192.168.100.210/zentao/')

        # 需要悬停的元素,悬停到语言选择框上
        hover = self.drive.find_element(By.CSS_SELECTOR, '[class="btn"]')
        # 鼠标悬停 ActionChains(浏览器).move_to_element(悬停的元素).perform() 执行操作
        ActionChains(self.drive).move_to_element(hover).perform()
        time.sleep(1)
		# 选择需要的语言
        self.drive.find_element(By.CSS_SELECTOR, '[data-value="zh-tw"]').click()

iframe切换/鼠标悬停为提高成功率,最好是在操作后sleep(1)秒

9、警告框处理

  • 禅道登陆演示
    在这里插入图片描述
    警告框处理:switch_to.alert
    def log_on(self):
        '''代码执行'''
        # 通过get()方法打开网页
        self.drive.get('http://192.168.100.210/zentao/')
        # 点击登陆
        self.drive.find_element(By.CSS_SELECTOR, '[id="submit"]').click()
        time.sleep(1)
        # 获取警告框的文本信息
        alert_msg = self.drive.switch_to.alert.text
        print(alert_msg)
        # 接受警告框 accept()
        self.drive.switch_to.alert.accept()
        # 取消警告框 dismiss()
        # self.drive.switch_to.alert.dismiss()

10、窗口切换

  • 切换窗口:switch_to.window(需要切换到的窗口)
    def log_on(self):
        '''代码执行'''
        # 打开百度
        self.drive.get('https://www.baidu.com/')
        # 搜索框输入:CSDN
        self.drive.find_element(By.CSS_SELECTOR, '[name="wd"]').send_keys("csdn")
        time.sleep(0.5)
        # 点击百度一下
        self.drive.find_element(By.CSS_SELECTOR, '[id="su"]').click()
        time.sleep(0.5)
        # 点击CSDN官网,开启新窗口,进入CSDN官网
        self.drive.find_element(By.LINK_TEXT, 'CSDN技术社区').click()
        time.sleep(3)
        # 获取所有窗口,以列表的形式返回过来
        all_windows = self.drive.window_handles
        print(all_windows)
        # 切换窗口,根据所有窗口的下标来切换,窗口顺序从0开始。(此时有两个窗口,第一个百度,第二个csdn)
        self.drive.switch_to.window(all_windows[0])

11、select标签的下拉框选择

  • 没有演示环境,就自己写一个html页面:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>演示数据</title>
</head>
<body>
    <select id="nr" name="wan">
        <option value="10">每页显示10条</option>
        <option value="20">每页显示20条</option>
        <option value="50">每页显示50条</option>
        <option value="100">每页显示100条</option>
    </select>
</body>
</html>
  • 首先需要先导入一个包(注意Select的S需要大写)
  • from selenium.webdriver.support.ui import Select
    def log_on(self):
        '''代码执行'''
        # 打开本地hthl页面
        self.drive.get('file:///C:/Users/Admin/Desktop/hthl.html')
        # 需要先定位到下拉框
        elements = self.drive.find_element(By.CSS_SELECTOR, '#nr')
        # Select(需要操作下拉框).根据什么操作
        time.sleep(2)
        Select(elements).select_by_index(1)  # 根据index,下标定位,从0开始
        time.sleep(2)
        Select(elements).select_by_value('100')  # 根据value定位
        time.sleep(2)
        Select(elements).select_by_visible_text('每页显示50条')  # 根据文本定位

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/99897.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Windows10 系统下载网址推荐(二)

Windows10 系统下载网址推荐&#xff08;二&#xff09;1. 计算机操作系统概述2.HelloWindows3. 山己几子木4. xitongku5. TechBench结束语1. 计算机操作系统概述 操作系统&#xff08;Operating System&#xff0c;OS&#xff09;是一组主管并控制计算机操作、运用和运行硬件…

设计一个接口务必考虑好这14个基本点

目录&#xff1a;导读 前言 1、入参合法性校验 2、接口的版本控制 3、接口考虑幂等性 4、接口考虑防止重复请求 5、提高接口的响应时间 6、接口限流控制 7、黑白IP白名单 8、敏感数据脱敏 9、请求接口的先决条件-token 10、记录接口请求日志 11、调用第三方接口要考…

分解优化react对redux的基础使用

之前写了 react18 通过redux 做一个简单的状态管理基站 但代码确实相对比较乱 这次进行一些小封装和分解 优化一下管理质量 首先 我们创建一个 react项目 然后在项目中引入 npm install redux --save在src目录下创建 reducers 文件夹 下面创建 counter.js counter.js 参考代码…

有什么免费python安装包?

前言 Python的安装涉及到&#xff1a;Python编辑器、Python解释器、Python包管理工具&#xff08;pip&#xff09;。因此&#xff0c;首先我们要搞清楚这三个东西都是啥。 Python编辑器 正如在电脑上编辑文档需要用Word、处理数据需要用Excel、做演示文稿需要用PPT、修图需要…

git add 命令详解

1. 前言 2. git add 基本操作 3. git add 命令参数 4. git add 背后做了什么 1. 前言 众所周知&#xff0c;git 中有工作区、暂存区、版本库三大组成部分 工作区: 电脑中能看到的目录&#xff0c;也就是写代码的地方 暂存区: 英文叫 stage 或 index。一般存放在 .git 目录下…

【图像分割】灰狼算法最小交叉熵多阈值图像分割【含Matlab源码 903期】

⛄一、最小交叉熵多阈值图像分割简介 1 单阈值分割 设有两个概率分布P{p1, p2, …, pN}和Q{q1, q2, …, qN}, 交叉熵度量它们之间的信息量差异。其对称形式为 交叉熵既可看成是采用P取代Q作为单个系统概率分布时系统信息量变化的期望值, 也可看成是两个概率系统P和Q之间的信息…

CSAPP-Lab5 CacheLab解析

Review Cache Struct A cache is a set of 2s2^s2s cache setsA cache set is a set of E cache lines if E1, it is called “direct-mapped” Each cache line stores a blockTotal Capacity S * B * E 由此&#xff0c;我们可以写出cache line和cache的结构&#xff1a; …

微服务框架 SpringCloud微服务架构 服务异步通讯 50 消息可靠性 50.4 失败重试机制 50.4.1 消费者失败重试

微服务框架 【SpringCloudRabbitMQDockerRedis搜索分布式&#xff0c;系统详解springcloud微服务技术栈课程|黑马程序员Java微服务】 服务异步通讯 文章目录微服务框架服务异步通讯50 消息可靠性50.4 失败重试机制50.4.1 消费者失败重试50 消息可靠性 50.4 失败重试机制 50…

可路由计算引擎实现前置数据库

❤️作者主页&#xff1a;小虚竹 ❤️作者简介&#xff1a;大家好,我是小虚竹。Java领域优质创作者&#x1f3c6;&#xff0c;CSDN博客专家&#x1f3c6;&#xff0c;华为云享专家&#x1f3c6;&#xff0c;掘金年度人气作者&#x1f3c6;&#xff0c;阿里云专家博主&#x1f3…

非零基础自学Golang 第9章 结构体 9.1 理解结构体 9.2 定义结构体 9.3 实例化结构体

非零基础自学Golang 文章目录非零基础自学Golang第9章 结构体9.1 理解结构体9.2 定义结构体9.3 实例化结构体9.3.1 标准实例化9.3.2 new函数实例化9.3.3 取地址实例化9.3.4 访问成员第9章 结构体 在Go语言官网的常见问题解答一栏中&#xff0c;有这样一个问题&#xff1a;“Is…

Fiddler(7):fiddler设置弱网测试

弱网测试 概念&#xff1a;弱网看字面意思就是网络比较弱&#xff0c;我们通称为信号差&#xff0c;网速慢。 意义&#xff1a;模拟在地铁、隧道、电梯和车库等场景下使用APP &#xff0c;网络会出现延时、中断和超时等情况。 Fiddler弱网测试流程&#xff1a; 一、限速操作…

基于云开发的微信小程序、QQ小程序详细教程(更新中)

云开发解决方案 小程序云开发解决方案 为企业和开发者提供一站式后端云服务&#xff0c;无需管理基础架构&#xff0c;一次开发多端运行&#xff0c;腾讯云和微信联合出品。 云开发&#xff08;Tencent CloudBase&#xff0c;TCB&#xff09;是腾讯云提供的云原生一体化开发环…

数据结构---大整数相加

大整数相加列竖式运算第一步第二步第三步第四步JAVA实现给出两个很大的整数&#xff0c;要求实现程序求出两个整数之和。 记得这个题目我大二ACM课程老师讲过&#xff0c;但是忘记了。。。。。。。。。。 列竖式运算 程序不可能通过一条指令计算出两个大整数之和&#xff0c;…

【学习打卡04】可解释机器学习笔记之Grad-CAM

可解释机器学习笔记之Grad-CAM 文章目录可解释机器学习笔记之Grad-CAMGrad-CAM介绍Grad-CAM是CAM的泛化形式Gard-CAM可视化结果Grad-CAM算法的优点Grad-CAM算法的缺点Grad-CAM变种Grad-CAMScore-CAMLayer-CAM思考与总结参考阅读首先非常感谢同济子豪兄拍摄的可解释机器学习公开…

SAP S4 FICO 固定资产模块后台配置详解

1. 概述 资产会计&#xff08;FI-AA&#xff09;作为总帐模块&#xff08;FI-GL&#xff09;的子分类帐&#xff0c;对企业的固定资产、无形资产、在 建工程、低值易耗品、长期待摊、从购置、资本化、折旧、调拨到出售/报废的整个生命周期 进行全过程的管理&#xff0c;并和…

java实现给微信群中定时推送消息

大家好&#xff0c;我是雄雄。 前言 上一篇&#xff0c;我们介绍了如何通过调用接口的方式&#xff0c;将每日新闻发送到自己的博客中。我们会发现&#xff0c;将新闻以文章的形式发布&#xff0c;并且相关内容按照markdown的形式进行格式调整&#xff0c;有需要的可以点击这里…

获取小程序生产、开发、体验等环境、版本信息、appid等信息

if (typeof __wxConfig "object"){const version __wxConfig.envVersion;console.log("当前环境:" version)if (version "develop"){cosole.log(测试 开发环境)}else if (version "trial"){cosole.log(测试 体验版)}else if (versio…

【电力系统】基于YALMIP+CPLEX求解带储能的微电网优化调度问题附matlab代码

✅作者简介&#xff1a;热爱科研的Matlab仿真开发者&#xff0c;修心和技术同步精进&#xff0c;matlab项目合作可私信。 &#x1f34e;个人主页&#xff1a;Matlab科研工作室 &#x1f34a;个人信条&#xff1a;格物致知。 更多Matlab仿真内容点击&#x1f447; 智能优化算法 …

【树莓派不吃灰】兄弟连篇② 文件编辑器vim与RPM软件包管理、yum

目录1、文件编辑器Vim1.1 工作模式1.2 插入命令1.3 定位命令1.4 删除命令1.5 复制和剪切命令1.6 替换和取消命令1.7 搜索和搜索替换命令1.8 保存和退出命令1.9 使用技巧2、yum包管理2.1 网络yum源2.2 yum命令2.3 rpm包与源码包安装位置❤️ 博客主页 单片机菜鸟哥&#xff0c;一…

联盛德W801开发板流水灯示例

联盛德W801开发板流水灯示例&#x1f4fa;&#x1f4fd;&#x1f39e;&#x1f3ac;本实验通过利用开发板中间的7个led&#xff0c;控制对应的IO实现流水灯效果。 &#x1f4dc;W801 32位WiFi蓝牙双模SoC开发板 &#x1f6e0;开发工具以及示例Demo工程 参考&#xff1a;《W801…