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

目录
  • 一、环境搭建
    • 1、python安装
    • 2、pycharm下载安装
    • 3、selenium下载安装
    • 4、浏览器驱动下载安装
  • 二、Selenium简介
    • (1)SeleniumIDE
    • (2)SeleniumRC
    • (3)SeleniumWebDriver
    • (4)SeleniumGrid
  • 三、常用方法
    • 1、浏览器操作
    • 2、如何获取页面元素
    • 3、查找定位页面元素的方法
    • 4、操作方法
    • 5、下拉框操作
    • 6、WINDOS弹窗
    • 7、iframe内嵌页面处理
    • 8、上传文件
    • 9、切换页面
    • 10、截图
    • 11、等待时间
    • 12、js注入
    • 13、断言方法及策略

一、环境搭建

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环境搭建的资料请关注我们其它相关文章!

(0)

相关推荐

  • selenium+python自动化测试之环境搭建

    最近由于公司有一个向谷歌网站上传文件的需求,需要进行web的自动化测试,选择了selenium这个自动化测试框架,以前没有接触过这门技术,所以研究了一下,使用python来实现自动化脚本,从环境搭建到实现脚本运行. selenium是一个用于Web应用程序测试的工具.Selenium测试直接运行在浏览器中,就像真正的用户在操作一样.支持的浏览器包括IE(7, 8, 9, 10, 11),Mozilla Firefox,Safari,Google Chrome,Opera等.支持自动录制动作和自动

  • Python+Selenium实现自动化的环境搭建的步骤(图文)

    1.在浏览器下载与浏览器相对于的驱动并放到python的安装根目录下 驱动的两个下载地址: http://chromedriver.storage.googleapis.com/index.html http://npm.taobao.org/mirrors/chromedriver/ a.先找到浏览器的版本 b.找到与浏览器对应的驱动 c.把下载好的驱动放到python安装目录的根目录下 2.点击设置 3.添加selenium 4.搜索selenium并添加 5.输入以下代码并运行,如果能打开

  • selenium+python自动化测试环境搭建步骤

    相对于自动化测试工具QTP来说,selenium小巧.免费,而且兼容Google.FireFox.IE多种浏览器,越来越多的人开始使用selenium进行自动化测试. 我是使用的python 2.7,下面说一下selenium+Python的自动化测试环境搭建. 安装Python环境,从python官网下载安装包 双击安装包,进行安装 可以选择python的安装目录,按步骤安装,直至完成. 在早期的版本中,需要单独安装setuptools和pip,在新的python安装包版本中已经集成了setu

  • Python + selenium自动化环境搭建的完整步骤

    前言 本文主要介绍了关于Python+selenium自动化环境搭建的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧 Python +selenium+googledriver 小白的血泪安装使,不停的总结写心得是理解透彻的毕竟之路 一,python的安装: 首先去Python的官网下载安装包:https://www.python.org/  ,大家也可以通过我们进行下载://www.jb51.net/softs/415916.html 2.下载完成后如下图所示 3.双

  • python+selenium开发环境搭建图文教程

    web 调试工具介绍和开发环境搭建 python与selenium开发环境搭建: 一.下载python软件:https://www.python.org/ 下载完后,进行安装,安装成功后,打开IDLE(Python 3.6.2),如下图: 如上图在里面输入print("Hello Wrod!")按回车,出现Hello Wrod!,说明已经把IDLE装好了,下面打开dos命令窗口输入Python按回车.如下图: 出现python版本号等信息说明python已经安装成功.如果出现错误信息,

  • Selenium+Python自动化脚本环境搭建的全过程

    目录 一.Python环境搭建 1.下载安装包 2.验证是否安装成功.以及是否有pip 3.安装Selenium libraries 二.安装谷歌浏览器和WebDriver 1.安装谷歌浏览器 2.下载WebDriver 3.配置环境变量 4.验证WebDriver是否安装成功 三. 完结 *本文仅介绍环境的搭建,不包含任何脚本编写教程. 先整体说一下需要用到工具 1.Python环境(包括pip) 2.谷歌浏览器(包括对应的WebDriver) 详细步骤: 一.Python环境搭建 1.下载安

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

    目录 一.环境搭建 1.python安装 2.pycharm下载安装 3.selenium下载安装 4.浏览器驱动下载安装 二.Selenium简介 (1)SeleniumIDE (2)SeleniumRC (3)SeleniumWebDriver (4)SeleniumGrid 三.常用方法 1.浏览器操作 2.如何获取页面元素 3.查找定位页面元素的方法 4.操作方法 5.下拉框操作 6.WINDOS弹窗 7.iframe内嵌页面处理 8.上传文件 9.切换页面 10.截图 11.等待时间

  • 手把手教你搭建python+selenium自动化环境(图文)

    目录 第一步:安装python解释器 第二步:安装pycharm编译器. 第三步:安装selenium库 第四步:下载浏览器的驱动 第五步:打开pycharm写第一个自动化demo验证环境是否有问题 快速+简单搭建环境.如果有问题,欢迎进群讨论留言. 第一步:安装python解释器 官网地址:https://www.python.org/ 自动化测试最好下载3.7的. 下载完成后打开这个文件,然后傻瓜式安装. 安装好后,win+r打开命令行窗口,输入python.如果显示下图,就说明安装成功.

  • python+selenium自动化框架搭建的方法步骤

    环境及使用软件信息 python 3 selenium 3.13.0 xlrd 1.1.0 chromedriver HTMLTestRunner 说明: selenium/xlrd只需要再python环境下使用pip install 名称即可进行对应的安装. 安装完成后可使用pip list查看自己的安装列表信息. chromedriver:版本需和自己的chrome浏览器对应,百度下载. 作用:对chrome浏览器进行驱动. HTMLTestRunner:HTMLTestRunner是Pyt

  • Python接口自动化之cookie、session应用详解

    目录 一.cookie 1.cookie介绍 2.cookie原理 二.session 1.session介绍 2.session原理 1. 存储位置不同: 2. 存储容量不同: 3. 存取方式不同: 4. 隐私策略/安全性不同: 5. 有效期不同: 6. 服务器压力不同: 三.cookie和session区别 四.cookie应用 五.session应用 在上一篇Python接口自动化测试系列文章:Python接口自动化之浅析requests模块post请求,介绍了post源码,data.js

  • C++中文件操作基础详解

    目录 文件操作 文件分类 文本文件 写文件 读文件 二进制文件 写文件 读文件 文件操作 意义:利用文件操作可以保存我们程序运行的信息,是持久化技术的体现 文件分类 按文件类型分为: 1.文本文件    -  文件以文本的ASCII码形式存储在计算机中 2.二进制文件 - 文件以文本的二进制形式存储在计算机中 按类分为: ofstream类:写操作 ifstream类: 读操作 fstream类: 读写操作 文本文件 写文件 五个步骤: 1.引入头文件 #include <fstream> 2

  • python+webdriver自动化环境搭建步骤详解

    python是一个很好脚本语言工具,现在也比较流行的一个脚本语言工具,对目前web自动化可以用的比较是webdriver框架进行自动化测试,脚本写起来较简单,运行的占用的内容较小.那么对windown下python+webdriver自动化环境如何进行搭建. 下载一个python.exe文件,直接默认安装即可 配置python的环境,指定到python的路径 安装pip环境,从网上下载一个pip,解压完成后,进入解压目录下执行python setup install 安装selenium文件,在

  • Python Web框架之Django框架Model基础详解

    本文实例讲述了Python Web框架之Django框架Model基础.分享给大家供大家参考,具体如下: model是关于你的数据的单一的,确定的信息来源. 它包含您正在存储的数据的基本字段和行为.Django通过抽象化的模型层(models)为你的网络应用提供对于数据的结构化处理和操作处理,数据库相关的代码一般写在 models.py 中,Django 支持 sqlite3, MySQL, PostgreSQL等数据库,使用数据库API对数据库进行增删改查的操作. 使用哪种数据库,只需要在se

  • python接口自动化之ConfigParser配置文件的使用详解

    前言:目前我们使用的绝大多数计算机程序,无论是办公软件,浏览器,甚至游戏.视频都是通过菜单界面系统配置的,它几乎成了我们使用机器的默认方式.而在python中,也有这样的一个配置模块可以把代码可配置化. 什么是配置文件 ​这里的配置文件不同于我们平常所见的可视化的菜单界面,它是像代码形式的,如下示例: ​❓为什么要做配置文件? ​✔️让代码和配置都变成可模块化可配置化,提高代码的重用性,那什么时候把它变成可配置化呢?多处地方都用到一个参数时,经常会变化的参数等,都可以可配置化,我们只需要在配置文

随机推荐