2023.8.25 关于 Selenium 常用 API 详解

news2025/1/23 7:25:01

目录

引言

打开页面

查找页面元素

 输入文本 

点击操作

提交操作

清除文本 

获取文本和属性值

​编辑

选择多个元素

获取页面标题和URL

等待操作

浏览器操作

多层框架定位

窗口操作

屏幕截图

下拉框元素选择操作

​编辑

执行脚本 

文件上传 


引言

本文讲的所有API均基于谷歌浏览器驱动,即 ChromeDriver 类中的 API

WebDriver webDriver = new ChromeDriver();

打开页面

webDriver.get("https://www.baidu.com");
  • 在 get 方法中输入想打开的网址,即可打开该网址页面

查找页面元素

//        找到百度搜索输入框
//        这是通过 CSS 选择器进行选择
        WebElement element = webDriver.findElement(By.cssSelector(".s_ipt"));
//        这是通过 xpath 选择器进行选择
        WebElement element = webDriver.findElement(By.xpath("//*[@id=\"kw\"]"));

CSS 选择语法(效率比 xpath 高)

id选择器:#id 

  • By.cssSelector("#kw")

类选择器:.class

  •  By.cssSelector(".s_ipt")

标签选择器:标签名

  •   By.cssSelector("input")

后代选择器:父级选择器 子级选择器

  •    By.cssSelector("form input")

XPath 选择语法

绝对路径:(不常用)

  •  By.xpath("/html/head/title")

相对路径:

相对路径+索引

  •   By.xpath("//form/span[1]/input")
相对路径+属性值
  •   By.xpath("//input[@class="s_ipt"]")
相对路径+通配符
  •    By.xpath("//*[@id="su"]")     

注意: ' * ' 符号 代表通配符 该示例表示任何一个标签其属性值 id 为 su 就会被选中

相对路径+文本匹配

  •     By.xpath("//a[text()="新闻"]")     

简捷方法:

通过在浏览器页面 按 F12 进行下面操作,直接获取到任意标签的 CSS 路径、XPath 路径

 

 输入文本 

//        找到百度搜索输入框
//        这是通过 Css 选择器进行选择
//        WebElement element = webDriver.findElement(By.cssSelector(".s_ipt"));
//        这是通过 xpath 选择器进行选择
        WebElement element = webDriver.findElement(By.xpath("//*[@id=\"kw\"]"));
//        在搜索框中输入
        element.sendKeys("不孕不育");
  • sendKeys 方法可对你选中的元素进行输入文本,但是仅适用于文本文字和内容可以编辑的元素

点击操作

//        找到百度一下按钮 并 点击
        webDriver.findElement(By.cssSelector("#su")).click();
  • 定位到选中元素使用 click 方法 即为鼠标的点击操作

提交操作

//        点击百度一下按钮
        webDriver.findElement(By.cssSelector("#su")).submit();
  • 定位到选中元素使用 submit 方法 即为按下 Enter 键效果一样
  • 不推荐使用 submit 方法,click 方法能完全代替 submit 方法

注意:

  • 选中元素在 from 标签中,使用 submit 方法 实现的效果和 click 方法 是一样的
  • 选中元素放在 非 from 标签中,使用 submit() 会报错

清除文本 

//        清空百度搜索输入框中的数据
        webDriver.findElement(By.cssSelector("#kw")).clear();
  • 定位到选中元素使用 clear 方法 即可清空其文本内容

获取文本和属性值

//        获取 选中标签的文本内容
        String text = webDriver.findElement(By.cssSelector("#hotsearch-content-wrapper > li:nth-child(3) > a > span.title-content-title")).getText();
  • 定位到选中元素使用 getText 方法 即可获取到该元素的文本内容

 

//        获取 属性名为 value 的值
        String button_value = webDriver.findElement(By.cssSelector("#su")).getAttribute("value");
  • 定位到选中元素使用 getAttribute 方法 即可获取到该元素 相应属性名 的值
  • 除了 value 属性值 也可获取 id 属性值、class 属性值、type 属性值 等等

选择多个元素

示例:自动选择 checkbox 类型的元素

List<WebElement> webElements = webDriver.findElements(By.cssSelector("input"));
        for (int i = 0; i < webElements.size(); i++) {
//            如果每个元素 type 值等于 checkbox 进行点击
            if(webElements.get(i).getAttribute("type").equals("checkbox")){
                webElements.get(i).click();
            }
        }
  • 使用 findElements 方法 获取到标签为 input 的元素集合

获取页面标题和URL

//        打开百度首页
        webDriver.get("https://www.baidu.com");
//        获取 get 方法所打开页面的 URL
        String url = webDriver.getCurrentUrl();
//        获取 get 方法所打开页面 标签为 title 的值
        String title = webDriver.getTitle();
  • 使用 getCurrentUrl 方法 即可获取 get 方法打开页面的 URL 值
  • 使用 getTitle 方法 即可获取 get 方法打开页面标签为 title 的值

等待操作

引言

  • 程序执行速度远快于浏览器渲染速度
  • 当自动化打开某一页面且需要选中该页面某一元素时
  • 情况1:在选择元素时,页面渲染完成,成功选中该元素
  • 情况2:在选中元素时,页面还未完全渲染(被选中元素还未加载出来),此时选择该元素时便会报错!
  • 为了避免 情况2 的发生,我们可以引入等待操作

强制等待

//        这是强制等待 3秒
        sleep(3000); 
  • 当自动化程序代码执行到 sleep 方法时,便会强制等待自定义时长,继而执行后面代码

隐式等待

//        创建驱动
        WebDriver webDriver = new ChromeDriver();
//        这是隐式等待 3天
        webDriver.manage().timeouts().implicitlyWait(3,TimeUnit.DAYS);
//        打开百度首页
        webDriver.get("https://www.baidu.com");
//        在搜索框输入"不孕不育" 
        webDriver.findElement(By.cssSelector("#kw")).sendKeys("不孕不育");
//        点击百度一下
        webDriver.findElement(By.cssSelector("#su")).click();
//        退出
        webDriver.quit();
  • 隐式等待贯穿于 webDriver 的整个生命周期
  • 在自定义时间内反复判断元素是否存在,直到元素能被找到,便停止等待
  • 超出自定义时间还未找到,便会报错
  • TimeUnit.DAYS 代表时间单位 天 ,也有秒、小时、分钟等单位,可自行选择

显式等待

//        显示等待 3秒
        WebDriverWait wait = new WebDriverWait(webDriver,3000);
//        等待至该元素被选择,才继续执行后面代码
        wait.until(ExpectedConditions.elementToBeClickable(By.cssSelector("#bottom_layer > div > p:nth-child(8)")));
//        等待至是否可以判断该元素的 title 标签为 ”百度一下,你就知道“ 才继续执行后面代码
        wait.until(ExpectedConditions.titleIs("百度一下,你就知道"));
  • 显式等待仅作用于某一条代码
  • 在自定义时间内判断 该条代码 元素是否存在,直到元素能被找到,便停止等待
  • 超出自定义时间还未找到,便会报错
  • 使用 until 方法,来自定义要进行显示等待的代码

浏览器操作

前进操作

//        浏览器前进
        webDriver.navigate().forward();

后退操作

//        浏览器后退
        webDriver.navigate().back();

刷新操作

//        浏览器刷新
        webDriver.navigate().refresh();

多层框架定位

 

//        先进行框架的定位
        webDriver.switchTo().frame("f1");
//        再进行元素的选择
        webDriver.findElement(By.cssSelector("body > div > div > a")).click();
  • 在含有多个框架的页面中,我们必须要先对框架进行定位,才能进行相应的元素选择

窗口操作

设置窗口大小

//        浏览器最大化
        webDriver.manage().window().maximize();
//        浏览器全屏
        webDriver.manage().window().fullscreen();
//        浏览器窗口设置指定大小 (宽 , 高)
        webDriver.manage().window().setSize(new Dimension(600,1000));

窗口切换

  • 操作窗口是指被 自动化代码 操作的窗口
  • 最初的操作窗口,是使用 get 方法 打开的窗口
  • 在操作窗口中打开新窗口,该新窗口不会变为操作窗口
  • 我们需用到窗口切换,来切换我们的操作窗口,使新窗口成为被 自动化代码 操作的窗口
  • 当浏览器每打开一个窗口时,会自动给每个窗口进行标识,也被称为 句柄
  • 句柄 是窗口切换操作的关键所在
//        通过 getWindowHandles 获取所有的窗口句柄
//        通过 getWindowHandle 获取 get 方法所打开的页面窗口句柄
        System.out.println(webDriver.getWindowHandle());
        Set<String> handles = webDriver.getWindowHandles();
        String target_handle = "";
//        这里的循环是为了获取到 新窗口 对应的句柄
        for (String handle:handles) {
            target_handle = handle;
            System.out.println("target_handle = " + target_handle);
        }
        webDriver.switchTo().window(target_handle);

屏幕截图

1.在 pom.xml 中引入相应依赖

<!-- https://mvnrepository.com/artifact/commons-io/commons-io -->
        <dependency>
            <groupId>commons-io</groupId>
            <artifactId>commons-io</artifactId>
            <version>2.11.0</version>
        </dependency>

2.截图操作代码

//        屏幕截图操作 OutputType.FILE 表示以文件的形式保存
        File file = ((TakesScreenshot)webDriver).getScreenshotAs(OutputType.FILE);
//        把文件存入 自定义路径下 没输入路径时,便是当前项目路径下
        FileUtils.copyFile(file,new File("E://20230826test.png"));
  • 在保存截图的时候我们可以为文件名加入时间戳,使得每次所得截图的文件名是动态的、不相同的,从而可以避免程序多次生成的截图因文件同名而被覆盖
  • 在有弹窗的情况下使用截图会报错

//        alert 弹窗取消
        webDriver.switchTo().alert().dismiss();
//        alert 弹窗中加入小林
        webDriver.switchTo().alert().sendKeys("小林");
//        alert 弹窗确定
        webDriver.switchTo().alert().accept();
  • 在提示弹窗进行输入文本的输入,在页面上是看不到输入文本的执行效果

下拉框元素选择操作

        WebElement element = webDriver.findElement(By.cssSelector("#ShippingMethod"));
        Select select = new Select(element);
//        根据下标进行选择 下标从 0 开始
        select.selectByIndex(3);
//        直接根据值进行选择
        select.selectByValue("12.51");
  • 先创建出一个 select 对象
  • selectByIndex 方法为下标选择法
  • selectByValue 方法为值选择法

执行脚本 

//        浏览器滚动条滚动
        ((JavascriptExecutor)webDriver).executeScript("document.documentElement.scrollTop=10000");
  • 先将 webDriver 转化为 JavascriptExecutor 类型
  • 再在 executeScript 方法填入 想执行的 JavaScript 代码,从而进行相应的页面操作

文件上传 

//    先选中 文件上传按钮 再进行上传文件 
    webDriver.findElement(By.cssSelector("input")).sendKeys("E:\\test.jpg");
  • 在 sendKeys 方法中填入 想要上传文件的 绝对路径

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

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

相关文章

汇编-内中断

中断的意思是指&#xff0c; CPU不再接着(刚执行完的指令) 向下执行&#xff0c; 而是转去处理这个特殊信息。 8086CPU&#xff0c;当CPU内部有下面的情况发生的时候&#xff0c; 将产生相应的中断信息&#xff1a; (1)除法错误&#xff0c; 比如&#xff0c; 执行div指令产生…

springboot中使用ElasticSearch

引入依赖 修改我们的pom.xml&#xff0c;加入spring-boot-starter-data-elasticsearch <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-elasticsearch</artifactId> </dependency>编写配…

如何有效进行RLHF的数据标注?

编者按&#xff1a;随着大语言模型在自然语言处理领域的广泛应用&#xff0c;如何从人类反馈进行强化学习&#xff08;RLHF&#xff09;已成为一个重要的技术挑战。并且RLHF需要大量高质量的人工数据标注&#xff0c;这是一个非常费力的过程。 本文作者在数据标注领域具有丰富经…

uniapp 开发之仿抖音,上下滑动切换视频、点击小爱心效果

效果图&#xff1a; 功能描述&#xff1a; 上下滑动视频&#xff0c;双击暂停&#xff0c;然后第一个视频再往上滑显示”已经滑到顶了“ 开始代码&#xff1a; 首先视频接口使用的公开的视频测试接口 开放API-2.0 官网展示 Swagger UI 接口文档 一…

DC电源模块不同的尺寸可以适应实际应用场景

BOSHIDA DC电源模块不同的尺寸可以适应实际应用场景 DC电源模块是现代电子设备的必备部件之一&#xff0c;其可提供稳定的直流电源&#xff0c;保证电子设备正常运行。DC电源模块尺寸的选择直接影响到其适应的应用场景及其性能表现。本文将从尺寸方面分析DC电源模块的适应性&a…

购买腾讯云服务器搭建网站全流程_新手建站

使用腾讯云服务器搭建网站全流程&#xff0c;包括轻量应用服务器和云服务器CVM建站教程&#xff0c;轻量可以使用应用镜像一键建站&#xff0c;云服务器CVM可以通过安装宝塔面板的方式来搭建网站&#xff0c;腾讯云服务器网分享使用腾讯云服务器建站教程&#xff0c;新手站长搭…

2023-08-28 LeetCode每日一题(插入区间)

2023-08-28每日一题 一、题目编号 57. 插入区间二、题目链接 点击跳转到题目位置 三、题目描述 给你一个 无重叠的 &#xff0c;按照区间起始端点排序的区间列表。 在列表中插入一个新的区间&#xff0c;你需要确保列表中的区间仍然有序且不重叠&#xff08;如果有必要的…

ARM寄存器组

CM3 拥有通用寄存器 R0‐R15 以及一些特殊功能寄存器。 R0-R7&#xff0c;通用目的寄存器 R0-R7也被称为低组寄存器&#xff0c;所有指令可以访问它们&#xff0c;它们的字长为32位&#xff0c;复位后的初始值是不可预料的。 R8-R12&#xff0c;通用目的寄存器 R8-R12也被称…

GNS3 在 Linux 上的安装指南

文章目录 GNS3 在 Linux 上的安装指南1. 基于 Ubuntu 的发行版安装 GNS32. 基于 Debian 的安装3. 基于 ArchLinux 的安装4. 从 Pypi 安装 GNS35. 启动 GNS3 服务端GNS3 在 Linux 上的安装指南 大家好,今天我们来聊聊如何在 Linux 上安装 GNS3。GNS3 是一个非常受欢迎的网络模…

C#,《小白学程序》第八课:列表(List)应用之二“编制高铁列车时刻表”

1 文本格式 /// <summary> /// 《小白学程序》第八课&#xff1a;列表&#xff08;List&#xff09;应用之二————编制高铁列车时刻表 /// 列车时刻表的每一行一般都是&#xff1a;车站 到达时间 出发时间 /// 两个车站之间的开行时间 time distance / speed /// 出发…

python web GUI框架-NiceGUI 教程(二)

python web GUI框架-NiceGUI 教程&#xff08;二&#xff09; streamlit可以在一些简单的场景下仍然推荐使用&#xff0c;但是streamlit实在不灵活&#xff0c;受限于它的核心机制&#xff0c;NiceGUI是一个灵活的web框架&#xff0c;可以做web网站也可以打包成独立的exe。 基…

系列十一、AOP

一、概述 1.1、官网 AOP的中文名称是面向切面编程或者面向方面编程&#xff0c;利用AOP可以对业务逻辑的各个部分进行隔离&#xff0c;从而使得业务逻辑各部分之间的耦合度降低&#xff0c;提高程序的可重用性&#xff0c;同时提高了开发的效率。 1.2、通俗描述 不通过…

MySQL中的free链表,flush链表,LRU链表

一、free链表 1、概述 free链表是一个双向链表数据结构&#xff0c;这个free链表里&#xff0c;每个节点就是一个空闲的缓存页的描述数据块的地址&#xff0c;也就是说&#xff0c;只要你一个缓存页是空闲的&#xff0c;那么他的描述数据块就会被放入这个free链表中。 刚开始数…

PHP自己的框架PDO数据表前缀、alias、model、table、join方法实现(完善篇九--结束)

一、实现功能&#xff0c;数据表前缀、alias、model、table、join方法实现 二、表前缀实现 1、config.php增加表前缀 DB_PEX>fa_,//数据库前缀 2、增加表前缀方法function.php function model($table){$modelnew ModelBase($table,config("DB_PEX"));return $m…

curl通过webdav操作alist

创建目录: url202320230828;curl -v -u "admin":"这里是密码" -X MKCOL "http://127.0.0.1:5244/dav/my189tianyi/${url2023}/" 上传文件: curl -v -u "admin":"这里是密码" -T /tmp/aa.json "http://127.0.0.1:52…

基于SSH的电影票预订系统

基于SSH的电影票预订系统 一、系统介绍二、功能展示1.其他系统实现五.获取源码 一、系统介绍 项目类型&#xff1a;Java web项目 项目名称&#xff1a;基于SSH的电影票预定系统 [dingpiao] 用户类型&#xff1a;有用户和管理员&#xff08;双角色&#xff09; 项目架构&…

C# 多线程交替按照指定顺序执行

1.关于AutoResetEvent和ManualResetEvent的区别解释如下&#xff1a; AutoResetEvent和ManualResetEvent是.NET中的两个线程同步类。它们之间的主要区别在于其释放信号的方式以及对等待线程的影响。 AutoResetEvent的作用是在等待的线程被信号唤醒后&#xff0c;将信号自动重…

Matlab图像处理-平移运算

几何运算 几何运算又称为几何变换&#xff0c;是将一幅图像中的坐标映射到另外一幅图像中的新坐标位置&#xff0c;它不改变图像的像素值&#xff0c;只是改变像素所在的几何位置&#xff0c;使原始图像按照需要产生位置、形状和大小的变化。 图像几何运算的一般定义为&#…

Atcoder Beginner Contest 317

A - Potions (atcoder.jp) AC代码: #include<iostream> #include<algorithm> #include<cstring> #include<cmath> #define endl \n //#define int long long using namespace std; typedef long long ll; const int N110; int a[N]; int n,h,x; void…

【高阶数据结构】map和set的介绍和使用 {关联式容器;键值对;map和set;multimap和multiset;OJ练习}

map和set的介绍和使用 一、关联式容器 关联式容器和序列式容器是C STL中的两种不同类型的容器。 关联式容器是基于键值对的容器&#xff0c;其中每个元素都有一个唯一的键值&#xff0c;可以通过键值来访问元素。关联式容器包括set、multiset、map和multimap。 序列式容器是…