Selenium 自动化 —— 高级交互(click、sendKeys、submit、clear、select)

2024-05-16 08:28

本文主要是介绍Selenium 自动化 —— 高级交互(click、sendKeys、submit、clear、select),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

更多关于Selenium的知识请访问CSND论坛“兰亭序咖啡”的专栏:专栏《Selenium 从入门到精通》

​​


1. 前言

这是我的《Selenium从入门到精通》专栏的第11篇文章,前面花了很多时间在元素的定位上。不管是爬虫和自动化,找到元素后,我们通常还会需要和这么网页元素做一些交互,比如:

  • 点击“注册”按钮
  • 在“账号文本框”中输入账号
  • 清空文本内容
  • 提交“注册表单”
  • 在“证件类型”下拉列表中选择身份证

Selenium WebDriver提供了一系列简洁而强大的API,可以通过它们直接操纵页面上的各类元素,从而模拟用户交互行为。和上面的需求基本对应:

  • click 模拟用户点击元素的动作
  • send keys 向可输入的文本元素发送文本数据
  • clear 清除文本元素中的内容
  • submit 模拟提交表单操作
  • select 处理下拉选择框

本文将系统性地介绍Selenium中对Web元素进行操作的五大核心命令,并通过Java代码示例展示其具体应用。

2. 五大核心命令

我们用Java和Junit来测试Selenium。测试结构:

@Slf4j
public class InteractionTest {private WebDriver driver = null;@BeforeEachpublic void setup(){driver = new ChromeDriver();}@AfterEachpublic void tearDown(){driver.quit();}@Testpublic void test() throws InterruptedException {// 测试代码写在这里!}
}

2.1 sendKeys() 输入文本

我们可以通过 sendKeys 可输入的文本元素(如输入框、可编辑区域)发送文本数据。

@Test
public void testSendKeys() throws InterruptedException {driver.get("https://www.baidu.com");WebElement searchBtn = driver.findElement(By.id("kw"));searchBtn.sendKeys("兰亭序咖啡的专栏");TimeUnit.SECONDS.sleep(5);
}

可以看到“兰亭序咖啡”被自动填写到用户名文本框。

2.2 click() 点击

click 可以模拟用户点击元素的动作,几乎适用于页面上的任何可点击元素,如按钮、链接等。

@Test
public void testClick() throws InterruptedException {driver.get("https://passport.baidu.com/v2/?reg");WebElement verifyCodeSend = driver.findElement(By.id("TANGRAM__PSP_4__verifyCodeSend"));verifyCodeSend.click();TimeUnit.SECONDS.sleep(5);
}

点击“获取验证码” 按钮

2.3 clear() 清空文本

clear() 用来清除文本元素中的内容,同样只适用于可输入的文本元素。

@Test
public void testClick() throws InterruptedException {driver.get("https://passport.baidu.com/v2/?reg");WebElement userName = driver.findElement(By.name("userName"));userName.sendKeys("兰亭序咖啡的专栏");TimeUnit.SECONDS.sleep(5);userName.clear();TimeUnit.SECONDS.sleep(5);
}

文本框先是被设置,然后等待几秒后被清空

2.4 submit() 提交表单

submit 用来 模拟提交表单操作,通常用于表单元素,当点击表单内的提交按钮时,会触发此操作。

@Test
public void testSubmit() throws InterruptedException {driver.get("https://passport.baidu.com/v2/?reg");driver.findElement(By.name("userName")).sendKeys("abab233214567");driver.findElement(By.id("TANGRAM__PSP_4__form")).submit();TimeUnit.SECONDS.sleep(5);
}

尝试提交表单(不经过点击“登录”按钮)

因为一些必填字段没有填写,所以提交不成功

2.5 select() 选择下拉列表

select() 专门用于处理下拉选择框(<select>元素),提供了丰富的选项选择方法,如按值、索引或文本选择。

@Test
public void testSelect() throws InterruptedException {driver.get("https://www.runoob.com/try/try.php?filename=tryhtml_option");WebElement dropdown = driver.findElement(By.xpath("//select"));Select select = new Select(dropdown);select.selectByIndex(3);select.selectByValue("saab");select.selectByVisibleText("Volvo");TimeUnit.SECONDS.sleep(5);
}

可以通过三种方式选中特定的下拉列表选项!

3. 高级交互的特点

其实除了本文要介绍的五大核心交互外,Selenium 还提供了更底层的Action类也可以实现类似的功能。那么它们有什么区别呢?

因为这五个核心交互命令是高级的交互,也就是模拟人类的操作,所以,它们有两个特别的点:

  • 如果元素不在页面的可视范围,它会滚动页面到元素的位置,然后再操作。
  • 做这些操作前,Selenium 会确保元素是可交互的。(interactable)。如果元素不可交互,会抛出ElementNotInteractableException的异常!

下面几种情况会抛出ElementNotInteractableException异常:

  • 元素不在可视范围内——比如被其它元素挡住了(比如loading框)
  • 元素没有显示——比如隐藏的元素
  • 不可点击——比如页面还在加载中,或者按钮是disabled状态

4. 结束语

本文介绍了五种常用的高级交互,通过Selenium提供的这些特性,我们可以用Selenium实现更丰富的功能。关注兰亭序咖啡,一起学习更多Selenium的知识。

这篇关于Selenium 自动化 —— 高级交互(click、sendKeys、submit、clear、select)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/994380

相关文章

深度解析Python yfinance的核心功能和高级用法

《深度解析Pythonyfinance的核心功能和高级用法》yfinance是一个功能强大且易于使用的Python库,用于从YahooFinance获取金融数据,本教程将深入探讨yfinance的核... 目录yfinance 深度解析教程 (python)1. 简介与安装1.1 什么是 yfinance?

Go中select多路复用的实现示例

《Go中select多路复用的实现示例》Go的select用于多通道通信,实现多路复用,支持随机选择、超时控制及非阻塞操作,建议合理使用以避免协程泄漏和死循环,感兴趣的可以了解一下... 目录一、什么是select基本语法:二、select 使用示例示例1:监听多个通道输入三、select的特性四、使用se

Python使用python-pptx自动化操作和生成PPT

《Python使用python-pptx自动化操作和生成PPT》这篇文章主要为大家详细介绍了如何使用python-pptx库实现PPT自动化,并提供实用的代码示例和应用场景,感兴趣的小伙伴可以跟随小编... 目录使用python-pptx操作PPT文档安装python-pptx基础概念创建新的PPT文档查看

基于Python编写自动化邮件发送程序(进阶版)

《基于Python编写自动化邮件发送程序(进阶版)》在数字化时代,自动化邮件发送功能已成为企业和个人提升工作效率的重要工具,本文将使用Python编写一个简单的自动化邮件发送程序,希望对大家有所帮助... 目录理解SMTP协议基础配置开发环境构建邮件发送函数核心逻辑实现完整发送流程添加附件支持功能实现htm

MySQL数据类型与表操作全指南( 从基础到高级实践)

《MySQL数据类型与表操作全指南(从基础到高级实践)》本文详解MySQL数据类型分类(数值、日期/时间、字符串)及表操作(创建、修改、维护),涵盖优化技巧如数据类型选择、备份、分区,强调规范设计与... 目录mysql数据类型详解数值类型日期时间类型字符串类型表操作全解析创建表修改表结构添加列修改列删除列

Python 函数详解:从基础语法到高级使用技巧

《Python函数详解:从基础语法到高级使用技巧》本文基于实例代码,全面讲解Python函数的定义、参数传递、变量作用域及类型标注等知识点,帮助初学者快速掌握函数的使用技巧,感兴趣的朋友跟随小编一起... 目录一、函数的基本概念与作用二、函数的定义与调用1. 无参函数2. 带参函数3. 带返回值的函数4.

Java Stream 的 Collectors.toMap高级应用与最佳实践

《JavaStream的Collectors.toMap高级应用与最佳实践》文章讲解JavaStreamAPI中Collectors.toMap的使用,涵盖基础语法、键冲突处理、自定义Map... 目录一、基础用法回顾二、处理键冲突三、自定义 Map 实现类型四、处理 null 值五、复杂值类型转换六、处理

Python调用LibreOffice处理自动化文档的完整指南

《Python调用LibreOffice处理自动化文档的完整指南》在数字化转型的浪潮中,文档处理自动化已成为提升效率的关键,LibreOffice作为开源办公软件的佼佼者,其命令行功能结合Python... 目录引言一、环境搭建:三步构建自动化基石1. 安装LibreOffice与python2. 验证安装

Go语言使用select监听多个channel的示例详解

《Go语言使用select监听多个channel的示例详解》本文将聚焦Go并发中的一个强力工具,select,这篇文章将通过实际案例学习如何优雅地监听多个Channel,实现多任务处理、超时控制和非阻... 目录一、前言:为什么要使用select二、实战目标三、案例代码:监听两个任务结果和超时四、运行示例五

python panda库从基础到高级操作分析

《pythonpanda库从基础到高级操作分析》本文介绍了Pandas库的核心功能,包括处理结构化数据的Series和DataFrame数据结构,数据读取、清洗、分组聚合、合并、时间序列分析及大数据... 目录1. Pandas 概述2. 基本操作:数据读取与查看3. 索引操作:精准定位数据4. Group