selenium脚本编写及八大元素定位方法

selenium脚本编写

上篇文章介绍了selenium环境搭建,搭建好之后就可以开始写代码了

基础脚本,打开一个网址

from selenium import webdriver
driver = webdriver.Chrome()#打开chrome浏览器
driver.get('https://www.baidu.com') #打开百度

打开本地HTML文件

上篇文章我自己写了一个html文件,放在了当前路径下

  • 第一种方式

通过绝对路径打开

from selenium import webdriver
driver = webdriver.Chrome()#打开chrome浏览器
driver.get(r'D:\sele_study\2-selenium\day1_sele\test.html')
  • 第二种方式

通过相对路径打开

本质上也是通过方法把相对路径转为绝对路径

#第一种转为绝对路径的方法
from selenium import webdriver
from pathlib import Path#pathlib:路径处理库
driver = webdriver.Chrome()#打开chrome浏览器
html = Path('./test.html')
driver.get(str(html.resolve()))#Path.resolve:该方法将一些的 路径/路径段 解析为绝对路径#第二种转为绝对路径的方法
from selenium import webdriver
import os
html = os.path.abspath('./test.html')#返回绝对路径
driver = webdriver.Chrome()
driver.get(html)
​现在我也找了很多测试的朋友,做了一个分享技术的交流群,共享了很多我们收集的技术文档和视频教程。
如果你不想再体验自学时找不到资源,没人解答问题,坚持几天便放弃的感受
可以加入我们一起交流。而且还有很多在自动化,性能,安全,测试开发等等方面有一定建树的技术大牛
分享他们的经验,还会分享很多直播讲座和技术沙龙
可以免费学习!划重点!开源的!!!
qq群号:485187702【暗号:csdn11】

优雅地打开浏览器(with)

用with打开浏览器,不用手工关闭

from selenium import webdriver
from time import sleep
with webdriver.Chrome() as driver:#with上下文管理器,不需要我去关闭driver.get('https://www.baidu.com')#打开百度sleep(5)#等5秒,自动关闭

认识webdriver对象方法和属性

初识元素定位方法

#祖宗方法 
find_element
#通过class属性的值定位(底层是css)
find_element_by_class_name
#√√√通过css 选择器定位(推荐,最快)
find_element_by_css_selector
#√通过id的值定位(底层是css)
find_element_by_id
#√通过a标签的文本定位(底层是XPATH)
find_element_by_link_text
#通过name属性的值来定位(底层是css)
find_element_by_name  
#通过a标签的部分文本定位(模糊匹配)(底层是XPATH)
find_element_by_partial_link_text
#通过标签名来定位(底层是css)
find_element_by_tag_name
#√√通过xpath方法定位(慢)
find_element_by_xpath            #以下方法的用法同上,只是返回的是一组元素(列表形式)
find_elements                        
find_elements_by_class_name          
find_elements_by_css_selector
find_elements_by_id
find_elements_by_link_text
find_elements_by_name
find_elements_by_partial_link_text
find_elements_by_tag_name
find_elements_by_xpath

除了祖宗方法,其他八种定位方式被大家称为‘selenium八大元素定位’

可以配合HTML全局属性介绍来理解这些方法。

HTML全局属性介绍:https://www.w3school.com.cn/tags/html_ref_standardattributes.asp

用法示例

以下方法演示用的是我们上篇文章写的HTML文件

需要的朋友可以去上篇文章复制或公众号后台输入‘html练习’获取源文件

  • find_element_by_name

通过name属性的值来定位

from selenium import webdriver
from pathlib import Path
from time import sleep
with webdriver.Chrome() as driver:#打开chrome浏览器html = Path('./test.html')driver.get(str(html.resolve()))#Path.resolve:该方法将一些的 路径/路径段 解析为绝对路径driver.find_element_by_name('username').send_keys('admin')#找到name的值为'username'的标签,并输入'admin'sleep(5)#5秒后关闭

知识点:

1.如果遇到重复的元素,操作的永远是第一个

2.send_keys方法,不会清空原来的内容

  • find_element_by_id

通过id的值定位

from selenium import webdriver
import os
from time import sleep
with webdriver.Chrome() as driver:html = os.path.abspath('./test.html')#获取绝对路径driver.get(html)driver.find_element_by_id('username').send_keys('admin')#找到id的值为'username'的标签,并输入'admin'sleep(5)

知识点:

1.id是唯一的

2.可能会变,需要注意识别

3.首字符是数字的要注意css的表达式(后续详细介绍)

  • find_element_by_class_name

通过class属性的值定位

from selenium import webdriver
import os
from time import sleep
with webdriver.Chrome() as driver:html = os.path.abspath('./test.html')#获取绝对路径driver.get(html)# 1. 输入用户名driver.find_element_by_class_name('aa').send_keys('admin')#找到class的值为'aa'的标签,并输入'admin'# 2. 输入密码# driver.find_element_by_class_name('bb cc').send_keys('123456')--错误写法driver.find_element_by_class_name('bb').send_keys('pass')#找到class的值为'bb'的标签,输入'pass'driver.find_element_by_class_name('cc').send_keys('word')#找到class的值为'cc'的标签,输入'word'sleep(5)

知识点:

1.class也容易重复

2.class ='bb cc'规定元素的一个或多个类名,等同于class1,class2='bb','cc'

所以不能直接用driver.find_element_by_class_name('bb cc')

  • find_element_by_link_text

通过a标签的全文本定位,需要文本完全匹配

from selenium import webdriver
import os
from time import sleep
with webdriver.Chrome() as driver:html = os.path.abspath('./test.html')#获取绝对路径driver.get(html)driver.find_element_by_link_text('百度一下,你就不知道').click()#找到文本为'百度一下,你就不知道'文本的a标签,并点击sleep(5)#等待5秒关闭
  • find_element_by_partial_link_text

通过a标签的部分文本定位(模糊匹配)

#方法二:模糊匹配
from selenium import webdriver
import os
from time import sleep
with webdriver.Chrome() as driver:html = os.path.abspath('./test.html')#获取绝对路径driver.get(html)driver.find_element_by_partial_link_text('必应').click()#找到包含'必应'文本的a标签,并点击sleep(5)#等待5秒关闭

知识点:

1.link_text 的两种定位方式只适用于a标签的文本

2.link_text 完全匹配

3.parti_link_text 部分(模糊)可以是开头是、包含、结尾是

4.click()点击

  • find_element_by_tag_name

通过标签名来定位,因为重复特别多,所以很少用,不做介绍。

  • find_element_by_css_selector

通过css 选择器定位(推荐,最快)

内容比较多且重要,之后单独文章做介绍。

  • find_element_by_xpath

通过xpath方法定位

内容比较多且重要,之后文章单独介绍。

最后感谢每一个认真阅读我文章的人,看着粉丝一路的上涨和关注,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走! 希望能帮助到你!【100%无套路免费领取】

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

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

相关文章

brat文本标注工具——安装

目录 一、Linux系统安装 1. centOS系统 2. Ubuntu系统 3. macOS系统 4.说明 二、Google Chrome安装 1. 打开命令行,切换到管理者权限 2. 安装依赖 3. 下载Google浏览器的安装包 4. 安装Google Chrome 三、yum更新 四、Apache安装 安装Apache 启动Apac…

threeJs引入模型使用3D模型(vite+React+Ts)

要在 Three.js 中使用 3D 模型,你需要加载模型文件并将其添加到场景中。Three.js 支持多种不同的模型格式,比如 OBJ、FBX、GLTF 等。 init vitelatest //创建一个vite的脚手架 选择react并配置Ts 安装three.js准备 npm install react-three/drei np…

a-select:远程搜索——防抖节流处理——基础积累

a-select:远程搜索——防抖节流处理——基础积累 效果图下拉筛选数据&#xff1a;远程搜索功能&#xff1a; 效果图 下拉筛选数据&#xff1a; <a-selectshow-searchv-model"form.jobPositionCode"placeholder"请选择岗位"style"width: 100%"…

Redis哈希对象(listpack介绍)

哈希对象的编码可以是ziplist或者hashtable。再redis5.0版本之后出现listpack&#xff0c;为了是代替ziplist。 一. 使用ziplist编码 ziplist编码的哈希对象使用压缩列表作为底层实现&#xff0c;每当有新的键值对要加入到哈希对象时&#xff0c;程序都会先将保存了键值对的键…

【Linux 静态IP配置】

静态IP配置 1.NAT模式设置2.设置静态ip3.重启网络4.查看ip 1.NAT模式设置 首先设置虚拟机中NAT模式的选项&#xff0c;打开VMware&#xff0c;点击“编辑”下的“虚拟网络编辑器”&#xff0c;设置NAT参数 注意&#xff1a; VMware Network Adapter VMnet8保证是启用状态 …

ClassCMS2.4漏洞复现

ClassCMS2.4漏洞复现 环境搭建 任意文件下载漏洞复现 漏洞成因 ClassCMS2.4漏洞复现 CMS源码在附件中 环境搭建 使用phpstudy2016搭建web环境&#xff0c;php版本为5.5 安装CMS 这里选择Mysql数据库进行安装 用户名和密码都写默认的admin方便记忆 输入完成后点击安装 点…

【性能测试】性能测试监控关键指标

系统指标 检测性能测试是否有bug的关键指标 1、系统指标——与用户场景及需求直接相关。 并发用户数&#xff1a;某一物理时刻同时向系统提交请求的用户数。平均响应时间&#xff1a;系统处理事务的响应时间的平均值&#xff0c;对于系统快速响应类页面&#xff0c;一般响应…

货代FOB条款卖方必备的知识:发货人都要承担哪些费用呢?

据统计&#xff0c;中国出口中以FOB成交的占到70%&#xff0c;但专家指出&#xff1a;FOB对出口商的风险更大&#xff0c;有可能造成货、款两空的结局。 目前我国出口合同以FOB价格条款成交的比例越来越大&#xff0c;而且收货人指定船公司的少&#xff0c;指定境外货代的多&am…

建设银行新余市分行积极开展国债下乡宣传活动

近日&#xff0c;为了普及国债知识&#xff0c;提高农村居民对国债的认知度和投资意识&#xff0c;建设银行新余市分行组织员工前往下村开展了一场国债下乡宣传活动。 活动当天&#xff0c;工作人员早早地来到了下乡地点&#xff0c;悬挂起了国债宣传横幅&#xff0c;并摆放了…

ESP32-Web-Server编程- 使用SSE 实时更新设备信息

ESP32-Web-Server编程- 使用SSE 实时更新设备信息 概述 如前所述&#xff0c;传统 HTTP 通信协议基于 Request-Apply&#xff08;请求-响应&#xff09;机制&#xff0c;浏览器&#xff08;客户端&#xff09;只能单向地向服务器发起请求&#xff0c;服务器无法主动向浏览器推…

java源码-数组

背景 上传图片&#xff0c;需要对图片格式进行校验&#xff0c;这是就可以使用数组 1、什么是数组&#xff1f; Java 语言中提供的数组是用来存储固定大小的同类型元素。 如&#xff1a;可以声明一个数组变量&#xff0c;如 numbers[100] 来代替直接声明 100 个独立变量 numb…

替代升级虚拟化 | ZStack Cloud云平台助力中节能镇江公司核心业务上云

数字经济正加速推动各行各业的高质量升级发展&#xff0c;云计算是数字经济的核心底层基础设施。作为云基础软件企业&#xff0c;云轴科技ZStack 坚持自主创新&#xff0c;自研架构&#xff0c;产品矩阵可全面覆盖数据中心云基础设施&#xff0c;针对虚拟化资源实现纳管、替代和…

用按层次顺序遍历二叉树的方法,设计算法统计树中度为1的结点数目

用按层次顺序遍历二叉树的方法&#xff0c;设计算法统计树中度为1的结点数目 代码思路&#xff1a; 层序遍历的实现需要借助一个辅助队列 首先将根结点入队&#xff0c;然后根出队&#xff0c;把根的两个子树入队 然后下面循环执行&#xff1a;队头元素出队&#xff0c;队头元…

如何通过降低设备六大损失帮助企业改善OEE

在各个行业中&#xff0c;改善设备综合效率OEE&#xff08;Overall Equipment Efficiency&#xff09;是企业实现高效生产和竞争优势的关键。然而&#xff0c;设备的六大损失常常影响着企业的OEE指标。本文将探讨如何通过降低这六大损失来帮助企业改善OEE&#xff0c;提高生产效…

2023年掌控安全学院CTF暖冬杯——数据流分析

前言&#xff1a;打工仔一枚&#xff0c;第一波上新的3题misc 做完了 再打ISCTF随便记录一下 PS&#xff1a;环境关了&#xff0c;题目描述忘记了&#xff0c;反正就是找flag。 筛选HTTP数据流 导出数据流慢慢看 ctrl F 搜flag 看到一条 有flag.txt 的数据 导出另存.zip 这里…

洗袜子的洗衣机哪款好?内衣洗衣机便宜好用的牌子

不得不说洗衣机的发明解放了我们的双手&#xff0c;而我们从小到大就有这个意识&#xff0c;贴身衣物不可以和普通的衣服一起丢进去洗衣机一起&#xff0c;而内衣裤上不仅有肉眼看见的污渍还有手上根本无法消灭的细菌&#xff0c;但是有一款专门可以将衣物上的细菌杀除的内衣洗…

java设计模式学习之【建造者模式】

文章目录 引言建造者模式简介定义与用途实现方式&#xff1a; 使用场景优势与劣势建造者模式在spring中的应用CD&#xff08;光盘&#xff09;的模拟示例UML 订单系统的模拟示例UML 代码地址 引言 建造者模式在创建复杂对象时展现出其强大的能力&#xff0c;特别是当这些对象需…

docker集群的详解以及超详细搭建

文章目录 一、问题引入1. 多容器位于同一主机2. 多容器位于不同主机 二、介绍三、特性四、概念1. 节点nodes2. 服务(service)和任务(task)3. 负载均衡 五、docker网络1. overlay网络 六、docker集群搭建1. 环境介绍2. 创建集群3. 集群网络4. 加入工作节点 七、部署可视化界面po…

数学建模-基于脑出血患者院前指标的多种机器学习预测模型构建及比较研究

基基于脑出血患者院前指标的多种机器学习预测模型构建及比较研究 整体求解过程概述(摘要) 卒中是全球致残率、致死率最高的疾病之一&#xff0c;其中脑出血&#xff08;Intracerebral hemorrhage&#xff0c;ICH&#xff09;患者仅占卒中患者的 20%&#xff0c;但致残、死亡人…

【Linux】ln命令使用

ln命令 ln是linux中又一个非常重要命令&#xff0c;请大家一定要熟悉。它的功能是为某一个文件在另外一个位置建立一个同步的链接&#xff0c;这个命令最常用的参数是-s&#xff0c;具体用法是&#xff1a;ln –s 源文件 目标文件。 当我们需要在不同的目录&#xff0c;用到相…