广告位联系
返回顶部
分享到

Python+Selenium自动化环境搭建与操作介绍

python 来源:互联网 作者:秩名 发布时间:2022-03-12 19:31:33 人浏览
摘要

一、环境搭建 1、python 安装 下载地址:https://www.python.org/downloads/ 选择合适的版本进行安装 根据自己的操作系统类型以及位数选择 WINDOS + R 输入cmd 打开DOS窗口,检查环境变量是否配置正

一、环境搭建

1、python 安装

下载地址:https://www.python.org/downloads/

选择合适的版本进行安装

在这里插入图片描述

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

在这里插入图片描述

WINDOS + R 输入cmd

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

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

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

2、pycharm 下载安装

(1)pycharm下载

下载地址:https://www.jetbrains.com/pycharm/download/#section=windows

右侧为社区版,开源免费

左侧为专业版,收费

在这里插入图片描述

(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安装包进行下载

下载地址:https://pypi.org/project/selenium/#files

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

或者

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

4、浏览器驱动下载安装

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

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

在这里插入图片描述

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

在这里插入图片描述

(1)Edge 驱动下载安装

下载地址:点击这里下载

注意版本一致,系统一致

在这里插入图片描述

(2)Chrome 驱动下载安装

下载地址:https://developer.microsoft.com/en-us/microsoft-edge/tools/webdriver/

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

在这里插入图片描述

点击相应版本进去

点击文件将自动下载

在这里插入图片描述

(3)IE 驱动下载安装

下载地址:https://www.selenium.dev/downloads/

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

在这里插入图片描述

其他版本下载地址:

下载地址:http://selenium-release.storage.googleapis.com/index.html

在这里插入图片描述

(4)Firefox 驱动下载安装

下载地址:http://selenium-release.storage.googleapis.com/index.html

这里是版本号:

在这里插入图片描述

在这里下载:

在这里插入图片描述

另外这个网站也可以下载

下载地址:https://ftp.mozilla.org/pub/firefox/releases/

二、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、浏览器操作

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

1

2

3

4

5

6

- webdriver.Chrome()            #打开谷歌浏览器

- webdriver.Firefox()           #打开火狐浏览器

- webdriver.Edge()              #打开Edge浏览器

- webdriver.Ie()                #打开IE浏览器

- webdriver.Safari()            #打开Safari浏览器

- webdriver.Opera()             #打开Opera浏览器

关闭浏览器

1

2

3

- quit()            #退出浏览器--退出整个浏览器 

- close()           #关闭浏览器--当前页面【开了多个页面时,无法关闭】 

- os.system('taskkill /im chrome.exe /F')   #杀死进程

刷新浏览器

1

dr.refresh()    #刷新

前进后退

1

2

dr.forward() #前进

dr.back()   #后退

调整窗口大小

1

2

3

dr.maximize_window()

dr.minimize_window()

dr.set_window_size(300,400)

访问URL地址

1

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、查找定位页面元素的方法

方式一 :

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

1

2

3

4

5

6

7

8

- 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_属性名('属性值')

示例:

1

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

方式二:

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

单个元素获取:

1

2

3

4

5

6

7

8

- 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="属性值")

多元素获取:

1

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

例子:

1

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、下拉框操作

1

2

3

4

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弹窗

1

2

3

4

5

6

7

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页面)

在这里插入图片描述

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

1

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

然后切换焦点

1

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

切换后执行操作

1

2

3

4

5

6

7

8

9

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()        #点击进入邮箱首页

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

1

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

8、上传文件

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

1

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

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

需要安装 pykeyboard 模块

1

2

3

4

5

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('新句柄')

1

2

3

4

5

6

7

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、截图

1

2

3

4

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),常用于获取文本前设置,单位秒

隐式等待:

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

1

dr.implicitly_wait(5)

显示等待:

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

1

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

12 、 js注入

(1) 滑动到指定位置

1

2

3

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

 

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

(2)上滑下滑页面

1

2

3

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

 

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

13 、断言方法及策略

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

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

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

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

4.断言方法

is_displayed()显示,存在


版权声明 : 本文内容来源于互联网或用户自行发布贡献,该文观点仅代表原作者本人。本站仅提供信息存储空间服务和不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权, 违法违规的内容, 请发送邮件至2530232025#qq.cn(#换@)举报,一经查实,本站将立刻删除。
原文链接 : https://blog.csdn.net/a883774913/article/details/122306149
相关文章
  • Python Django教程之实现新闻应用程序

    Python Django教程之实现新闻应用程序
    Django是一个用Python编写的高级框架,它允许我们创建服务器端Web应用程序。在本文中,我们将了解如何使用Django创建新闻应用程序。 我们将
  • 书写Python代码的一种更优雅方式(推荐!)

    书写Python代码的一种更优雅方式(推荐!)
    一些比较熟悉pandas的读者朋友应该经常会使用query()、eval()、pipe()、assign()等pandas的常用方法,书写可读性很高的「链式」数据分析处理代码
  • Python灰度变换中伽马变换分析实现

    Python灰度变换中伽马变换分析实现
    1. 介绍 伽马变换主要目的是对比度拉伸,将图像灰度较低的部分进行修正 伽马变换针对的是对单个像素点的变换,也就是点对点的映射 形
  • 使用OpenCV实现迷宫解密的全过程

    使用OpenCV实现迷宫解密的全过程
    一、你能自己走出迷宫吗? 如下图所示,可以看到是一张较为复杂的迷宫图,相信也有人尝试过自己一点一点的找出口,但我们肉眼来解谜
  • Python中的数据精度问题的介绍

    Python中的数据精度问题的介绍
    一、python运算时精度问题 1.运行时精度问题 在Python中(其他语言中也存在这个问题,这是计算机采用二进制导致的),有时候由于二进制和
  • Python随机值生成的常用方法

    Python随机值生成的常用方法
    一、随机整数 1.包含上下限:[a, b] 1 2 3 4 import random #1、随机整数:包含上下限:[a, b] for i in range(10): print(random.randint(0,5),end= | ) 查看运行结
  • Python字典高级用法深入分析讲解
    一、 collections 中 defaultdict 的使用 1.字典的键映射多个值 将下面的列表转成字典 l = [(a,2),(b,3),(a,1),(b,4),(a,3),(a,1),(b,3)] 一个字典就是一个键对
  • Python浅析多态与鸭子类型使用实例
    什么多态:同一事物有多种形态 为何要有多态=》多态会带来什么样的特性,多态性 多态性指的是可以在不考虑对象具体类型的情况下而直
  • Python字典高级用法深入分析介绍
    一、 collections 中 defaultdict 的使用 1.字典的键映射多个值 将下面的列表转成字典 l = [(a,2),(b,3),(a,1),(b,4),(a,3),(a,1),(b,3)] 一个字典就是一个键对
  • Python淘宝或京东等秒杀抢购脚本实现(秒杀脚本

    Python淘宝或京东等秒杀抢购脚本实现(秒杀脚本
    我们的目标是秒杀淘宝或京东等的订单,这里面有几个关键点,首先需要登录淘宝或京东,其次你需要准备好订单,最后要在指定时间快速
  • 本站所有内容来源于互联网或用户自行发布,本站仅提供信息存储空间服务,不拥有版权,不承担法律责任。如有侵犯您的权益,请您联系站长处理!
  • Copyright © 2017-2022 F11.CN All Rights Reserved. F11站长开发者网 版权所有 | 苏ICP备2022031554号-1 | 51LA统计