selenium(4)-------自动化测试脚本(python)

webdriverAPI

一)定位元素的方式,必问

1.1)id来定位元素,前提是元素必须具有id属性,因为有的元素是没有id的

1.2)name,元素必须有name,并且必须全局唯一

1.3)tagname,元素是一定有的,但是必须全局唯一才可以定位到元素

1.4)classname,class的名字,必须全局唯一

1.5)link_text,通过链接内容来进行定位,但是必须是全局唯一的

1.6)partial link text,部分的链接内容,必须是全局唯一的

1.7)css selector

1.8)xpath

二)等待

1)固定等待 time.sleep() 必须等待好参数设定的时间

2)driver.implicity_wait() 是智能等待,最多等待参数设定的时间,但是不一定等待足够的时间,只要下一条执行的语句的元素一出现那么就停止等待

send_keys(Keys.CONTROL,'a') #全选(Ctrl+A)

send_keys(Keys.CONTROL,'c') #复制(Ctrl+C)

send_keys(Keys.CONTROL,'x') #剪贴(Ctrl+X)

send_keys(Keys.CONTROL,'v') #粘贴(Ctrl+V)

学习python,推荐廖雪峰的官方网站

定位一组元素中的某一个元素:当前元素的界面是这样子的

现在我们使用checkbox.html来进行批量操作一组元素:

1)仍然使用的是老方法,先进行选中所有的input标签,在进行选中,预设的场景就是选中所有的checkbox标签而不选中radio标签,根据id或者xpath或者是xssselector进行定位即可

#我们这个界面操作的主要是把所有的checkbox都打上勾,而我们的所有radio都不会发生任何影响
#我们需要把所有的checkbox定位到,然后再进行打勾
#我们首先要使用我们的系统函数,因为我们此时打开的不是一个网址,而是一个系统页面,所以我们就需要使用os进行拼接url
import os
from selenium import webdriver
import time;
driver=webdriver.Edge("C:\Program Files\Python310\Scripts\msedgedriver.exe");
file="file:///"+os.path.abspath("D:\\checkbox.html");
#想要在浏览器上面打开一个本地的文件,必须加上file:///这个文件前缀,这就相当于拼接一个文件的绝对路径+文件名字
driver.get(file);
driver.maximize_window();
#先选中checkbox元素,然后我们在进行点击
driver.find_element_by_id("c1").click();
driver.find_element_by_id("c2").click();
driver.find_element_by_id("c3").click();
time.sleep(2);
driver.quit();

像这样的一个一个的定位元素的方式实在是太麻烦了,使用起来很不方便

2)现在我们选择批量定位操作一组元素的方法来进行操作,先进行选中所有的input标签所以可以使用tagname来进行定位,通过遍历的方式来进行选择是否要进行点击,如果选中的是checkbox那么就直接进行点击,如果input标签是radio那么就直接进行跳过;

import os;
from selenium import webdriver;
import time
driver=webdriver.Edge("C:\Program Files\Python310\Scripts\msedgedriver.exe");
file="file:///"+os.path.abspath("D:\\checkbox.html");
driver.get(file);
driver.maximize_window();
#1.先进行选中所有的input标签,定位一组tagname都是input的元素
inputs=driver.find_elements_by_tag_name("input");
#2.我们从这些元素中查询出type=checkbox元素,选中进行点击
for input in inputs:
        if input.get_attribute('type')=='checkbox':
            input.click();
time.sleep(6);
driver.quit();

嵌套选择标签框架:

是html页面里面有进行嵌套着html页面

 

框架嵌套框架:

1)frame1在我们的完整页面上面,然后frame1框架里面又套了一层frame2框架,frame2框架里面有一个百度页面里面有搜索输入框,显然通过我们之前的方法是无法进行访问到百度搜索框的,所以我们的核心解决方法就是先进行定位到最里面的frame1标签,我们在进行选中frame2标签,再选中元素进行操作,最外层的页面是没有百度搜索输入框的;

2)但是假设咱们进入到了frame2标签里面,成功地进行了搜索和点击按钮功能,但是在执行完这个操作之后,我们要进行点击frame1里面的一个名字叫做click的按钮,那么我们如何进行点击呢,在frame1可以找到frame2,但是我们在frame2里面就不可以找到frame1
f2在f1外边:

#转换层级:
driver.switch_to.frame("f1");
driver.switch_to.frame("f2");
#选择frame2里面的输入框和按钮:
driver.find_element_by_id("kw").send_keys("半拉图");
driver.find_element_by_id("su").click();
这样我们就可以顺利的输入我们要搜索的内容并点击按钮
#转换到frame1里面
driver.switch_to.frame("f1");
driver.find_element_by_link_text("click").click();
#因为这里面的frame1里面的这个按钮名字就叫做click,所以可以选择此方式进行选中

 3)所以我们的默认方法是先回到默认页面,在进入到f1页面里面,在后再进行操作click;

#先进性转换层级到f2来进行操作页面上面的元素,根据id来进行切换
driver.switch_to.frame("f1");
driver.switch_to.frame("f2");

driver.find_element_by_id("kw").send_keys("小姐姐");
driver.find_element_by_id("su").click();
#我们现在回到默认页面
driver.switch_to.defalut_content();
#选中里面的f1从而去操作咱们对应的click标签
driver.find_element_by_link_text("click").click();
time.sleep(1);
driver.quit();

1)我们要先把这一层打开,然后再从这一层的基础上进行操作,比如说下拉框,我们要先进行点击下拉框,我们才可以针对这里面的元素进行操作:

2)如果页面有框架时,要层层进入,才能取得对应框架内的元素,当进入到一个框架的子框架时,又要返回去获得它父框架的元素,只能重新跳转到默认的全局页面,重新去层层进入对应的框架中拿到元素

 进行层级定位:

我们从本质上可以先进行选择link1这个a标签,然后从这个a标签里面会弹出四个选项,然后我们就可以继续进行点击,跳转页面

代码思路:

1)先进行选中link1(在咱们的全局页面就有)按钮(find_element_by_link_text(”link1");

2)我们将link1所在的a标签进行点击:

3)我们在进行选中ul标签,通过id属性进行选中,然后再次利用鼠标属性进行点击

4)总而言之就是先选中ul标签,再选中ul标签里面li里面的a标签,因为打开的每一条都是一个连接

这就是我们上面的网页的源代码:

1)我们先进行选中ul上面的a标签,里面的内容是link1,所以我们要先进行选中link1,然后在进行点击 

2)选中ul标签里面的li标签,再进行选中a标签,最后进行鼠标选中操作

import time
from selenium import webdriver
from selenium.webdriver.common.action_chains import ActionChains
import os
driver=webdriver.Edge("C:\Program Files\Python310\Scripts\msedgedriver.exe");
file="file:///"+os.path.abspath("D:\selenium2html\level_locate.html");
driver.get(file);
time.sleep(2);
driver.maximize_window();
#先进行选中link1标签,然后进行点击,显示出现的链接,下拉列表,选择特定的元素
driver.find_element_by_link_text("Link1").click();
#选中ul中的li标签进行选中
time.sleep(2);
a=driver.find_element_by_id("dropdown1");
#再选中li中的Another action
sz=a.find_element_by_link_text("Another action");
time.sleep(3)
#在进行鼠标拖动操作,把鼠标放在元素上面,进行高亮显示
ActionChains(driver).move_to_element(sz).perform();
time.sleep(3);
driver.quit();

第二种定位方法:

1)先进行定位link1这个a标签,进行点击,显示出下面的四个文字

2)再次进行定位页面中出现的Another action,并且把鼠标移动到Another action上面

from selenium import webdriver
import time
from selenium.webdriver.common.action_chains import ActionChains
# 进行指定本地文件的url
url = "D:\selenium2html\level_locate.html"
# 获取到浏览器的驱动
driver=webdriver.Edge("C://Users//18947//AppData//Local//Programs//Python//Python310//msedgedriver.exe")
driver.get(url)
# 定位到浏览器的Link1标签链接并进行点击,显示四个文字部分
# driver.find_element_by_xpath("/html/body/div[1]/div/div/a").click()通过xpath来定位页面上的唯一元素
driver.find_element_by_link_text("Link1").click()
time.sleep(3)
# 选择要进行点击的文字并进行鼠标放置
a = driver.find_element_by_link_text("Another action")
ActionChains(driver).move_to_element(a).perform()
time.sleep(3)

 下拉框选择:我们将通过四种方式来进行打开我们的下拉框:

选择要显示哪一个直接通过xpath来进行定位要显示的内容即可,不用先进行选中最外面的select标签,再来选中里面的元素

第一种方法:通过xpath的方式直接进行定位

from selenium import webdriver;
import time
import os
driver=webdriver.Edge("C:\Program Files\Python310\Scripts\msedgedriver.exe");
file="file:///"+os.path.abspath("D:\selenium2html\\drop_down.html");
driver.get(file);
driver.maximize_window();
time.sleep(3);
#第一种方式,直接通过xpath的方式来进行选中,我们可以直接点击下拉框,选择option按钮,右键复制选择对应的xpath路径
ele=driver.find_element_by_xpath("//*[@id=\"ShippingMethod\"]/option[2]");
ele.click();
time.sleep(3);
driver.quit();

 第二种方法:直接通过css selector的方式来进行定位:

from selenium import webdriver
import os
import time
driver=webdriver.Edge("C:\Program Files\Python310\Scripts\msedgedriver.exe");
filepath="file:///"+os.path.abspath("D:\selenium2html\\drop_down.html");
driver.get(filepath);
driver.maximize_window();
time.sleep(3);
#先进行选中我们要进行点击的标签
ele=driver.find_element_by_css_selector("#ShippingMethod > option:nth-child(3)");
ele.click();
time.sleep(3);
driver.quit();

第三种方法:先定位一组元素,通过遍历标签集合的方式来进行遍历我们的options元素,可以根据特殊的value属性来进行筛选了

from selenium import webdriver
import time;
import os
driver=webdriver.Edge("C:\Program Files\Python310\Scripts\msedgedriver.exe");
filepath="file:///"+os.path.abspath("D:\selenium2html\\drop_down.html");
driver.get(filepath);
driver.maximize_window();
options=driver.find_element_by_xpath("//*[@id=\"ShippingMethod\"]").find_elements_by_tag_name("option");
time.sleep(2);
#下面我们通过遍历的方式来进行获取到options中的每一个元素,再通过option元素中的value属性从而判断一个具体的option标签,相当于是for each的方式来遍历
for option in options:
    if option.get_attribute("value")=="7.45":
     option.click();
time.sleep(2);
driver.quit();

第四种方法:通过访问数组元素下标的方式来进行点击

from selenium import webdriver;
import time;
import os;
driver=webdriver.Edge("C:\Program Files\Python310\Scripts\msedgedriver.exe");
filepath="file:///"+os.path.abspath("D:\selenium2html\\drop_down.html");
#通过浏览器进行打开文件
driver.get(filepath);
#选中ul标签,再选中里面所有的option标签,直接选中数组元素下标进行访问
time.sleep(2);
options=driver.find_element_by_id("ShippingMethod").find_elements_by_tag_name("option");
options[2].click();
time.sleep(3);
driver.quit();
from selenium import webdriver
import time
from selenium.webdriver.common.action_chains import ActionChains
driver=webdriver.Edge("C://Users//18947//AppData//Local//Programs//Python//Python310//msedgedriver.exe")
url="D:\selenium2html\\drop_down.html"
driver.get(url)
options=driver.find_element_by_css_selector("#ShippingMethod").find_elements_by_tag_name("option")
options[5].click()
time.sleep(3)

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

HTTP 缓存的工作原理

缓存是解决http1.1当中的性能问题主要手段。缓存可能存在于客户端浏览器上,也可以存在服务器上面,当使用过期缓存可能给用户展示的是错误的信息而导致一些bug。 HTTP 缓存:为当前请求复用前请求的响应 • 目标:减少时延&#xff1…

Python+Yolov8目标识别特征检测

Yolov8目标识别特征检测如需安装运行环境或远程调试&#xff0c;见文章底部个人QQ名片&#xff0c;由专业技术人员远程协助&#xff01;前言这篇博客针对<<Yolov8目标识别特征检测>>编写代码&#xff0c;代码整洁&#xff0c;规则&#xff0c;易读。 学习与应用推荐…

3分钟看完-丄-Python自动化测试【项目实战解析】经验分享

目录&#xff1a;导读 引言 自动化测试 背景 测试团队 测试体系发展 测试平台 自动化测试现状 现状一&#xff1a; 现状二&#xff1a; 现状三&#xff1a; 现状四&#xff1a; 现状五&#xff1a; 现状六&#xff1a; 失败的背景 失败的经历 失败总结 引言 内…

Java多线程系列--synchronized的原理

原文网址&#xff1a;Java多线程系列--synchronized的原理_IT利刃出鞘的博客-CSDN博客 简介 本文介绍Java的synchronized的原理。 反编译出字节码 Test.java public class Test {private static Object LOCK new Object();public static int main(String[] args) {synchro…

动态矢量瓦片缓存库方案

目录 前言 二、实现步骤 1.将数据写入postgis数据库 2.将矢量瓦片数据写入缓存库 3.瓦片接口实现 4.瓦片局部更新接口实现 总结 前言 矢量瓦片作为webgis目前最优秀的数据格式&#xff0c;其主要特点就是解决了大批量数据在前端渲染时出现加载缓慢、卡顿的问题&#xff0…

LeetCode 112. 路径总和

LeetCode 112. 路径总和 给你二叉树的根节点 root 和一个表示目标和的整数 targetSum 。判断该树中是否存在 根节点到叶子节点 的路径&#xff0c;这条路径上所有节点值相加等于目标和 targetSum 。如果存在&#xff0c;返回 true &#xff1b;否则&#xff0c;返回 false 。 叶…

Python笔记 -- 文件和异常

文章目录1、文件1.1、with关键字1.2、逐行读取1.3、写入模式1.4、多行写入2、异常2.1、try-except-else2.2、pass1、文件 1.1、with关键字 with关键字用于自动管理资源 使用with可以让python在合适的时候释放资源 python会将文本解读为字符串 # -*- encoding:utf-8 -*- # 如…

Linux操作系统基础的常用命令

1&#xff0c;Linux简介Linux是一种自由和开放源码的操作系统&#xff0c;存在着许多不同的Linux版本&#xff0c;但它们都使用了Linux内核。Linux可安装在各种计算机硬件设备中&#xff0c;比如手机、平板电脑、路由器、台式计算机。1.1Linux介绍Linux出现于1991年&#xff0c…

操作技巧 | 在Revit中借用CAD填充图案的方法

在建模过程中&#xff0c;有时需要达到多种填充效果&#xff0c;而CAD中大量的二维填充图案&#xff0c;便是最直接的资源之一。 使用 填充图案之前 使用 填充图案之后 其中要用到主要命令便是对表面填充图案的添加与编辑 简单效果 如下 模型填充与绘图填充 区别 模型填…

Java for循环嵌套for循环,你需要懂的代码性能优化技巧

前言 本篇分析的技巧点其实是比较常见的&#xff0c;但是最近的几次的代码评审还是发现有不少兄弟没注意到。 所以还是想拿出来说下。 正文 是个什么场景呢&#xff1f; 就是 for循环 里面还有 for循环&#xff0c; 然后做一些数据匹配、处理 这种场景。 我们结合实例代码来…

SpringBoot+WebSocket实时监控异常

# 写在前面此异常非彼异常&#xff0c;标题所说的异常是业务上的异常。最近做了一个需求&#xff0c;消防的设备巡检&#xff0c;如果巡检发现异常&#xff0c;通过手机端提交&#xff0c;后台的实时监控页面实时获取到该设备的信息及位置&#xff0c;然后安排员工去处理。因为…

Java实现调用第三方相关接口(附详细思路)

目录1.0.简单版2.0.升级版2-1.call.timeout()怎么传入新的超时值2-2.timeout(10, TimeUnit.SECONDS)两个参数的意思&#xff0c;具体含义3.0.进阶版3-1.java.net.SocketTimeoutException: 超时如何解决4.0.终极版1.0.简单版 以下是一个使用 Java 实际请求“第三方”的简单示例代…

一眼看破五花八门的链表结构

文章目录&#x1f4d5;一&#xff1a;五花八门的链表结构&#x1f4d6;链表与数组的简单对比&#x1f4d6;单链表&#x1f4d6;循环链表&#x1f4d6;双向链表&#x1f4d5;二&#xff1a;链表VS数组性能大比拼&#x1f47f;最后说一句&#x1f431;‍&#x1f409;作者简介&am…

数据挖掘(2.1)--数据预处理

一、基础知识 1.数据的基本概念 1.1基础知识 数据是数据对象(Data Objects)及其属性(Attributes)的集合。 数据对象(一条记录、一个实体、一个案例、一个样本等)是对一个事物或者物理对象的描述。 数据对象的属性则是这个对象的性质或特征&#xff0c;例如一个人的肤色、眼球…

GPT-4 性能炸天:10 秒做出一个网站,在考试中击败 90% 人类

一、GPT-4&#xff0c;吊打ChatGPT&#xff01; 一觉醒来&#xff0c;万众期待的 GPT-4&#xff0c;它来了&#xff01; OpenAI老板Sam Altman直接开门见山地介绍道&#xff1a;这是我们迄今为止功能最强大的模型&#xff01; 二、GPT-4&#xff0c;新功能一览 究竟有多强&am…

Python人脸识别

#头文件&#xff1a;import cv2 as cvimport numpy as npimport osfrom PIL import Imageimport xlsxwriterimport psutilimport time#人脸录入def get_image_name(name):name_map {f.split(.)[1]:int(f.split(.)[0]) for f in os.listdir("./picture")}if not name…

Java的jar包打包成exe应用

将springboot项目使用maven打出的jar包&#xff0c;打成windows平台下exe应用程序包&#xff08;自带jre环境&#xff09;。 工具&#xff1a;1、exe4j 2、Inno Setup 工具放到网盘&#xff0c;链接&#xff1a;https://pan.baidu.com/s/1ZHX8P7u-7GBxaC6uaIC8Ag 提取码&#x…

SpringBoot-核心技术篇

技术掌握导图 六个大标题↓ 配置文件web开发数据访问单元测试指标指控原理解析 配置文件 1.文件类型 1.1、properties 同以前的properties用法 1.2、yaml 1.2.1、简介 YAML是 “YAML Aint Markup Language”&#xff08;YAML不是一种标记语言&#xff09;的递归缩写。在…

76.qt qml-QianWindow开源炫酷界面框架(支持白色暗黑渐变自定义控件均以适配)

界面介绍界面支持: 透明 白色 黑色 渐变 单色 静态图 动态图侧边栏支持:抽屉、带折叠、多模式场景控件已集成: 暗黑风格 高亮风格、并附带个人自定义控件及开源demo白色场景如下所示:单色暗黑风格如下所示:用户自定义皮肤如下所示:皮肤预览如下所示:b站入口:https://www.bilibi…

2023年跨境电商行业研究报告

第一章 行业发展 1.1 概况 跨境电商&#xff08;Cross-border e-commerce&#xff09;是指通过互联网销售商品或服务&#xff0c;跨越国家或地区边界&#xff0c;实现国际贸易的一种商业模式。跨境电商的兴起得益于全球化和数字化的趋势&#xff0c;以及互联网的普及和支付、…