Python+Selenium自动化环境搭建与操作基础详解

 更新时间:2022年03月11日 16:30:43   作者:佛系的老肖  
Selenium是如今最常用的自动化测试工具之一,支持快速开发自动化测试框架,且支持在多种浏览器上执行测试。本文将介绍关于Selenium Python自动化脚本环境搭建的相关资料,需要的朋友可以参考下

一、环境搭建

1、python 安装

下载地址:点击这里下载

选择合适的版本进行安装

在这里插入图片描述

根据自己的操作系统类型以及位数选择

在这里插入图片描述

WINDOS + R 输入cmd

打开DOS窗口,检查环境变量是否配置正确

(1)python -V ,返回python版本号

(2)pip -V ,返回pip工具版本号

2、pycharm 下载安装

(1)pycharm下载

下载地址:点击这里下载

右侧为社区版,开源免费

左侧为专业版,收费

在这里插入图片描述

(2) 安装

运行exe程序,点击【Next】

在这里插入图片描述

选择安装目录后,点击【Next】

在这里插入图片描述

勾选相关选项后点击【Next】

在这里插入图片描述

点击【Install】完成安装

等待安装完成即可

在这里插入图片描述

点击【Finish】完成安装

(3)创建项目

运行pycharm,点击【New Project】

在这里插入图片描述

配置项目基本信息

(1) 选择项目的存储路径

(2) 选择项目依赖的Python库,会在项目中创建一个venv的虚拟环境

(3) 关联本地的Python解释器,如果不想使用venv可以选择本地解释器的可执行文件

建议选择New environment using, 然后在Base interpreter中选择前面安装的Python解释器的路径。这样做的好处:每个项目都是独立的空间,不会存在版本依赖冲突的问题,冲分发挥了虚拟环境的灵活性。修改完毕之后,点击Creat,创建项目。这样就创建了一个最初始的空项目

在这里插入图片描述

创建脚本

在项目名称上点击鼠标右键,创建一个python文件

在这里插入图片描述

输入脚本名称,按Enter键创建文件

在这里插入图片描述

3、selenium 下载安装

(1) 通过 pip 命令下载

WINDOS + R 输入CMD 打开DOS窗口

输入:pip insatall selenium

在这里插入图片描述

如果在安装时出现了以下内容,就是pip版本的问题,

在这里插入图片描述

输入:python.exe -m pip install --upgrade pip 升级一下版本就行

在这里插入图片描述

安装完成后 可以在 python>lib>site-packages目录下查看

在这里插入图片描述

(2) 通过 pycharm 下载

打开pycharm 点击左上角 【file】 选择 settings

在这里插入图片描述

选择项目 ,点击【+】

在这里插入图片描述

输入selenium ,选择合适的版本(可以不选择版本) 双击进行安装

在这里插入图片描述

(3) 通过下载selenium安装包进行下载

下载地址:点击这里下载

下载完成后放在 python>lib>site-packages 目录下

或者

项目所在位置 如 D:\pythonProject\venv\Lib\site-packages

4、浏览器驱动下载安装

注意!!! 驱动版本必须要和浏览器版本一致

查看浏览器版本一般在浏览器设置中的关于里面,用Edge浏览器举例:版本号为:版本 96.0.1054.62

在这里插入图片描述

驱动下载后放置于放在python根目录下

在这里插入图片描述

(1)Edge 驱动下载安装

下载地址:点击这里下载

注意版本一致,系统一致

在这里插入图片描述

(2)Chrome 驱动下载安装

下载地址:点击这里下载

Chrome驱动 浏览器最新版在网页靠近下方位置

在这里插入图片描述

点击相应版本进去

点击文件将自动下载

在这里插入图片描述

(3)IE 驱动下载安装

下载地址:点击这里下载

官网有4.0版的IE驱动,点击即可下载

在这里插入图片描述

其他版本下载地址:

下载地址:点击这里下载

在这里插入图片描述

(4)Firefox 驱动下载安装

下载地址:点击这里下载

这里是版本号:

在这里插入图片描述

在这里下载:

在这里插入图片描述

另外这个网站也可以下载

下载地址:点击这里下载

二、Selenium 简介

Selenium 是什么?

Selenium是针对Web应用的开源自动化测试工具,通过编写模拟用户操作的脚本,它会打开浏览器对Web应用进行黑盒测试。可以方便的用于功能测试、兼容性测试、 稳定性测试及并发测试。目前已被主流浏览器厂商广泛支持,同时也是很多其它自动化测试工具(比如,RobotFramework)的底层核心技术。Selenium由IDE、Remote Control(简称RC)、WebDriver、Grid四个工程组成:

(1)Selenium IDE

是一个用于录制/回放测试脚本的Firefox附加组件,录制的脚本可以生成基于Selenium RC的测试代码(Java、Ruby、C#等)。适用于快速入门,不太适用于实际较大的测试项目;

(2)Selenium RC

RC由Server和Client组成两部分组成,Server负责加载/关闭浏览器以及作为HTTP代理来访问Web应用,Clinet支持多种编程语言和测试框架(TestNG、JUnit、NUnit等)。

(3)Selenium WebDriver

WebDriver作为Selenium2的核心特性提供比RC更简洁易用的API,是官方推荐的RC替代方案。可以更好的支持动态网页,不需要再额外启动一个独立的Server。

(4)Selenium Grid

是Selenium的一个扩展工具,可以很方便地同时在多台机器上和异构环境中并行运行多个RC或WebDriver用例。

三、常用方法

1、浏览器操作

打开浏览器: (必须具备相应的驱动程序,如果打不开,基本是驱动程序配置有问题)

- webdriver.Chrome()			#打开谷歌浏览器
- webdriver.Firefox()			#打开火狐浏览器
- webdriver.Edge()				#打开Edge浏览器
- webdriver.Ie()				#打开IE浏览器
- webdriver.Safari()			#打开Safari浏览器
- webdriver.Opera() 			#打开Opera浏览器

关闭浏览器

- quit()			#退出浏览器--退出整个浏览器  
- close()			#关闭浏览器--当前页面【开了多个页面时,无法关闭】  
- os.system('taskkill /im chrome.exe /F')   #杀死进程

刷新浏览器

dr.refresh()    #刷新

前进后退

dr.forward() #前进
dr.back()   #后退

调整窗口大小

dr.maximize_window()
dr.minimize_window()
dr.set_window_size(300,400)

访问URL地址

dr.get('http://192.168.14.162:8081/agileone1/')

2、如何获取页面元素

首先打开浏览器,按F12 进入开发者模式

在这里插入图片描述

点击右上角三个点,可以选择开发框停靠位置,点击元素即可查看页面属性详情

在这里插入图片描述

使用开发栏左上角检查功能 快捷键CTRL+SHIFT+C,鼠标悬停至一个元素时,会自动定位到HTML元素位置

在这里插入图片描述

当我们定位到该元素的时候 ,可以去查看它包含了哪些属性,适合使用哪些属性进行定位:

属性定位优先级 : ID>Name>CSS>XPath

快捷复制元素属性值的方法:

1、选择合适的属性,双击 CTRL+C

在这里插入图片描述

2、定位到属性后鼠标邮件,选择复制(COPY)—> 选择合适的类型

在这里插入图片描述

3、查找定位页面元素的方法

方式一 :

单个元素获取 (有时候会提示此种方式已经被抛弃了,可以选择第二种方式进行获取)

    - driver.find_element_by_id('username')  				#通过id获取
    - driver.find_element_by_class_name('login-password')  	#通过class获取
    - driver.find_element_by_name('')  						#通过name 属性获取
    - driver.find_element_by_link_text('※ 公告管理 ※') 	#通过超链接文本获取  
    - driver.find_element_by_partial_link_text('公告管理') 	#通过超链接文本部分获取  
    - driver.find_element_by_css_selector('input#username.login-username')  #通过CSS获取
    - driver.find_element_by_tag_name('input')  			#通过tag name定位
    - driver.find_element_by_xpath('//*[@id="username"])   	#通过xpath定位

批量元素获取

driver.find_elements_by_属性名('属性值')

示例:

driver.find_elements_by_class_name('form-control')[0].send_keys('admin')

方式二:

需要导入模块 from selenium.webdriver.common.by import By

单个元素获取:

- driver.find_element(by=By.ID,value="属性值")	#通过ID定位
- driver.find_element(by=By.XPATH,value="属性值")
- driver.find_element(by=By.CLASS_NAME,value="属性值")
- driver.find_element(by=By.CSS_SELECTOR,value="属性值")
- driver.find_element(by=By.NAME,value="属性值")
- driver.find_element(by=By.LINK_TEXT,value="属性值")
- driver.find_element(by=By.TAG_NAME,value="属性值")
- driver.find_element(by=By.PARTIAL_LINK_TEXT,value="属性值")

多元素获取:

driver.find_elements(by=By.ID,value='属性值')[索引位置].send_keys('输入的内容')

例子:

driver.find_elements(by=By.ID,value='username')[0].send_keys('admin')

4、操作方法

代码操作
send_keys(‘输入内容’)输入文本
click()点击
clear()清空
text获取文本信息
double_click双击
context_click右键
move_to_element悬停
drag_and_drop(before,after)拖拽

5、下拉框操作

Select(driver.find_element_by_id('scope')).select_by_visible_text('所有项目') #依据文本  

Select(driver.find_element_by_id('scope')).select_by_index(1)		#依据索引位置  

Select(driver.find_element_by_id('scope')).select_by_value('0')	#依据value值

6、WINDOS弹窗

 driver.switch_to.alert().accept()  	#alert--提示确认:

driver.switch_to.alert.dismiss()		#取消

driver.switch_to.alert.send_keys() 		#文本提示

driver.switch_to.alert.text				#获取提示框中的文本信息

7、iframe内嵌页面处理

处理镶嵌在HTML页面中iframe页面(一个HTML页面中包裹着另一个HTML页面)

在这里插入图片描述

首选需要定位到该内嵌页面:

iframe=driver.find_element(by="xpath",value="/html/body/div[2]/div[3]/div[1]/div/div[4]/div[1]/div[1]/iframe")

然后切换焦点

driver.switch_to.frame(iframe)   #切换至内嵌页面

切换后执行操作

		driver.find_element(by="name",value="email").clear()    #清除内容
        time.sleep(0.5)
        driver.find_element(by="name",value="email").send_keys("a123456")	#输入账户
        time.sleep(0.5)
        driver.find_element(by="name",value="password").clear()    #清除内容
        time.sleep(0.5)
        driver.find_element(by="name", value="password").send_keys("a123456")	#输入密码
        time.sleep(0.5)
        driver.find_element(by="id",value="dologin").click()        #点击进入邮箱首页

执行完成后切换至父级界面

driver.switch_to.parent_frame()  # 切回父级页面

8、上传文件

1、针对与<input>标签,以及 type=file 类型,可以直接输用send_keys

driver.find_element_by_id("imgfile").send_keys("D:\pictyres\selenium.png")

2、使用键盘事件上传文件

需要安装 pykeyboard 模块

driver.find_element_by_xpath('元素位置').click() 
pk=PyKeyboard()    #实例化
pk.type_string(r'文件路径')
pk.press_key(pk.enter_key)  #按压
pk.release_key(pk.enter_key)  #释放

9、切换页面

句柄切换 driver.switch_to.window('新句柄')

for handle in driver.window_handles:	#遍历
	if handle !=driver.current_window_handle:	
		driver.switch_to.window(handle)

#句柄切换
driver.swithch_to_window(driver.window_handles[-1])
print(driver.current_window_handle)

10、截图

 		driver.get_screenshot_as_file(filename)
        driver.save_screenshot(filename)
        driver.get_screenshot_as_png()
        driver.get_screenshot_as_base64()

以下是我在实际运用中获取截图写入数据库的一个方法

在这里插入图片描述

11、等待时间

强制等待 :

首先需要导包 import time

time.sleep(2),常用于获取文本前设置,单位秒

隐式等待:

常用于初始化时,设置全局等待

dr.implicitly_wait(5)

显示等待:

常用于指定元素出现时方可操作

WebDriverWait(driver=dr,timeout=5,poll_frequency=0.5).until(lambda dr:dr.find_element_by_link_text('注销'))

12 、 js注入

(1) 滑动到指定位置

target = driver.find_elements_by_class_name(f"属性值")[0]  # 获取元素

driver.execute_script("arguments[0].scrollIntoView();", target)  # 滑动到指定元素位置

(2)上滑下滑页面

driver.execute_script('window.scrollBy(0,600)')  # 下滑页面

driver.execute_script('window.scrollBy(0,-600)')  # 上滑页面

13 、断言方法及策略

在断言时,应尽可能的使用and方法覆盖以下断言方法

1.检查文本提示信息是否满足预期

2.检查数据后台数据是否正确(后台 前端)—数据库断言 表 字段pymysql 连接 游标 SQL 获取结果

3.业务洛基断言:选择关联的功能来确定正确性,比如:上传文件,断言:搜索文件是否存在且一致

4.断言方法

is_displayed()显示,存在

以上就是Python+Selenium自动化环境搭建与操作基础详解的详细内容,更多关于Python Selenium环境搭建的资料请关注脚本之家其它相关文章!

相关文章

  • 利用Pycharm + Django搭建一个简单Python Web项目的步骤

    利用Pycharm + Django搭建一个简单Python Web项目的步骤

    这篇文章主要介绍了利用Pycharm + Django搭建一个简单Python Web项目的步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-10-10
  • python 随机生成emoji表情的方法实现

    python 随机生成emoji表情的方法实现

    本文主要介绍了python 随机生成emoji表情的方法实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-09-09
  • Python操作Redis数据库的详细教程与应用实战

    Python操作Redis数据库的详细教程与应用实战

    Redis是一个高性能的键值存储数据库,支持多种类型的数据结构,如字符串、哈希表、列表、集合和有序集合等,在Python中,通过redis-py库可以方便地操作Redis数据库,本文将详细介绍如何在Python代码中操作Redis,需要的朋友可以参考下
    2024-08-08
  • 使用python半分钟轻松完成证件照换底色

    使用python半分钟轻松完成证件照换底色

    是不是很多小伙伴儿都不清楚公司是需要蓝底还是红底的证件照,今天小编直接带大家做一款Python换底色的一款小程序,不管什么底色儿,放马过来
    2021-09-09
  • python基于BeautifulSoup实现抓取网页指定内容的方法

    python基于BeautifulSoup实现抓取网页指定内容的方法

    这篇文章主要介绍了python基于BeautifulSoup实现抓取网页指定内容的方法,涉及Python使用BeautifulSoup模块解析html网页的相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-07-07
  • 解决django FileFIELD的编码问题

    解决django FileFIELD的编码问题

    这篇文章主要介绍了解决django FileFIELD的编码问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-03-03
  • 简述python Scrapy框架

    简述python Scrapy框架

    这篇文章主要介绍了python Scrapy框架的相关资料,帮助大家开始学习python 爬虫,感兴趣的朋友可以了解下
    2020-08-08
  • Python实现给文件添加内容及得到文件信息的方法

    Python实现给文件添加内容及得到文件信息的方法

    这篇文章主要介绍了Python实现给文件添加内容及得到文件信息的方法,可实现从文件开头添加内容的功能,需要的朋友可以参考下
    2015-05-05
  • Python+matplotlib实现量场图的绘制

    Python+matplotlib实现量场图的绘制

    matplotlib是基于Python语言的开源项目,pyplot提供一系列绘制2D图形的方法。本文将带大家学习matplotlib.pyplot.quiver()相关方法属性并通过其绘制量场图
    2021-12-12
  • Python 实现图像逐像素点取邻域数据

    Python 实现图像逐像素点取邻域数据

    这篇文章主要介绍了Python 实现图像逐像素点取邻域数据,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-03-03

最新评论