新用户注册入口 老用户登录入口

[转载]Selenium-WebDriverApi介绍

文章作者:转载 更新时间:2023-12-03 12:51:11 阅读数量:44
文章标签:浏览器操作元素定位页面刷新窗口大小调整属性获取与操作页面截屏
本文摘要:该文专注于Selenium在Web自动化测试中的应用,详细阐述了如何利用Chrome浏览器进行页面刷新、前进后退等基础操作,并通过实例演示了8种核心的元素定位策略,包括ID、class_name、name、xpath、css Selector等。同时,文章还介绍了调整窗口大小、位置以及最大化窗口的方法,展示了执行JavaScript语句以操控浏览器行为的技巧,以及如何关闭单个页面或退出所有页面。此外,针对页面元素的各种属性操作,如获取源码、标题、URL,以及Element API中的属性值获取、输入文本、清除内容、模拟点击事件等功能也进行了详尽说明,并提供了页面截屏与元素截图的实际运用。通过这些丰富的功能和方法,Selenium为Web自动化测试提供了强大且全面的支持。
转载文章

本篇文章为转载内容。原文链接:https://blog.csdn.net/weixin_34377065/article/details/94686128。

该文由互联网用户投稿提供,文中观点代表作者本人意见,并不代表本站的立场。

作为信息平台,本站仅提供文章转载服务,并不拥有其所有权,也不对文章内容的真实性、准确性和合法性承担责任。

如发现本文存在侵权、违法、违规或事实不符的情况,请及时联系我们,我们将第一时间进行核实并删除相应内容。

浏览器操作

#刷新
driver.refresh()
from selenium import webdriver
driver=webdriver.Chrome()
driver.get('http://www.baidu.com')
import time
time.sleep(2)
driver.refresh()#前进
driver.forward()
#后退
driver.back

获取标签元素

from selenium import webdriver
driver=webdriver.Chrome()
driver.get('http://www.imdsx.cn')

#通过ID定位目标元素 driver.find_element_by_id('i1').send_keys(1111)#向页面发送文本‘11111’
# 通过className定位目标元素 driver.find_element_by_class_name('c1').send_keys(1111)
#通过name属性定位目标元素 driver.find_element_by_name('n1').send_keys(1111)
#通过Xpath属性定位目标元素 driver.find_element_by_xpath('//input[@placeholder="请通过XPATH定位元素"]').send_keys(1111)
#通过css Selector定位目标元素 driver.find_element_by_css_selector('[maxlength="20"]').send_keys(2222)
# 通过标签名称定位(注:在一个页面中,标签一定会重复,所以不用这个来进行定位) driver.find_element_by_tag_name('input').send_keys('tag name')
#通过标签中的文本查找元素 driver.find_element_by_link_text('登录').click()
#通过标签中文本的模糊匹配查找 driver.find_element_by_partial_link_text('录').click()

获取标签元素常用的一共有8种定位方式,而Selenium实际提供了18种定位方式,还有8种是上面的复数形式,实际种一般用不到,还有2种是这上面16种的底层封装。参数化的一种调用方式。

复数:

e=driver.find_elements_by_class_name('classname')[0]
e.send_keys(1111)
print(e)
print(type(e))接受两个参数 形参1 以什么形式定位  形参2 定位value是什么
driver.find_element_by_id('i1')
driver.find_element('id','i1').send_keys(1111)
driver.find_elements('id','i1')[0].send_keys(2222)

一般都直接用driver.find_element_by_css_selector(),因为底层只要符合w3c的都转化为css_selector

窗口操作:

#获取当前浏览器的大小
driver.get_window_size()
#通过宽和高对size进行设置
driver.set_window_size('100','200')
# 获取当前窗口针对于Windows的位置的坐标x,y
driver.get_window_position()# 设置当前窗口针对Windows的位置,x,y
driver.set_window_position(20,20)# 最大化当前窗口,不需要传参
driver.maximize_window()# 返回当前操作的浏览器句柄
driver.current_window_handle# 返回所有打开server的浏览器句柄
driver.window_handles
截取当前页面:
from selenium import webdriver
driver=webdriver.Chrome()
driver.get("http://www.baidu.com")
driver.get_screenshot_as_file('d.png')

执行JavaScript语句
# 执行JavaScript语句
driver.execute_script('window.scrollTo(0,0);')#执行js的api,通过js来操作滚动条,滚动到最上面

关闭与退出:

#当开启多个页面时,关闭当前页面
driver.close()
#退出并关闭所有页面驱动
driver.quit()
from selenium import webdriver
driver=webdriver.Chrome()
driver.get("http://ui.imdsx.cn/uitester/")
driver.maximize_window()#将窗口放大
driver.execute_script('window.scrollTo(0,0);')#执行js的api
driver.find_element_by_css_selector('[href="/new-index/"]').click()
handles=driver.window_handles#返回所有打开server的浏览器句柄
print(handles)#返回list
driver.switch_to.window(handles[1])
driver.find_element_by_css_selector('#newtag').send_keys(1111)#找到新页面上的元素
driver.close()#关闭当前tab页
from selenium import webdriver
driver=webdriver.Chrome()
driver.get("http://ui.imdsx.cn/uitester/")
driver.maximize_window()#将窗口放大
driver.execute_script('window.scrollTo(0,0);')#执行js的api
driver.find_element_by_css_selector('[href="/new-index/"]').click()
handles=driver.window_handles
print(handles)
driver.switch_to.window(handles[1])
driver.find_element_by_css_selector('#newtag').send_keys(1111)
driver.quit() #关闭所有页面,结束服务

 

其他

# 返回页面源码
driver.page_source# 返回tag标题
driver.title# 返回当前Url
driver.current_url# 获取浏览器名称 如:chrome
driver.name

ElementApi接口

#根据标签属性名称,获取属性value
element.get_attribute('style')
# 向输入框输入字符串 如果input的type为file类型 可以输入文件绝对路径上传文件
element.send_keys()
# 清除文本内容
element.clear()
# 鼠标左键点击操作
element.click()# 通过属性名称获取属性
element.get_property('id')# 返回元素是否可见 True or False
element.is_displayed()# 返回元素是否被选中 True or False
element.is_selected()# 返回标签元素的名字
element.tag_name# 获取当前标签的宽和高
element.size# 获取元素的文本内容
element.text# 模仿回车按钮 提交数据
element.submit()# 获取当前元素的坐标
element.location# 截取图片
element.screenshot()
from selenium import webdriver
driver=webdriver.Chrome()
driver.get("http://ui.imdsx.cn/uitester/")
driver.maximize_window()#将窗口放大
driver.execute_script('window.scrollTo(0,0);')#执行js的api
e=driver.find_element_by_css_selector('#i1')
e.send_keys(1111)
import time
time.sleep(1)
e.clear() #清除文本框内内容

 



 

转载于:https://www.cnblogs.com/wxcx/p/8934540.html

本篇文章为转载内容。原文链接:https://blog.csdn.net/weixin_34377065/article/details/94686128。

该文由互联网用户投稿提供,文中观点代表作者本人意见,并不代表本站的立场。

作为信息平台,本站仅提供文章转载服务,并不拥有其所有权,也不对文章内容的真实性、准确性和合法性承担责任。

如发现本文存在侵权、违法、违规或事实不符的情况,请及时联系我们,我们将第一时间进行核实并删除相应内容。

相关阅读
文章标题:[转载][洛谷P1082]同余方程

更新时间:2023-02-18
[转载][洛谷P1082]同余方程
文章标题:[转载]webpack优化之HappyPack实战

更新时间:2023-08-07
[转载]webpack优化之HappyPack实战
文章标题:[转载]oracle 同时更新多表,在Oracle数据库中同时更新两张表的简单方法

更新时间:2023-09-10
[转载]oracle 同时更新多表,在Oracle数据库中同时更新两张表的简单方法
文章标题:[转载][Unity] 包括场景互动与射击要素的俯视角闯关游戏Demo

更新时间:2024-03-11
[转载][Unity] 包括场景互动与射击要素的俯视角闯关游戏Demo
文章标题:[转载]程序员也分三六九等?等级差异,一个看不起一个!

更新时间:2024-05-10
[转载]程序员也分三六九等?等级差异,一个看不起一个!
文章标题:[转载]海贼王 动漫 全集目录 分章节 精彩打斗剧集

更新时间:2024-01-12
[转载]海贼王 动漫 全集目录 分章节 精彩打斗剧集
名词解释
作为当前文章的名词解释,仅对当前文章有效。
SeleniumSelenium是一个开源的Web应用程序测试工具集,主要用于自动化浏览器操作,支持多种浏览器(如Chrome、Firefox等)以及多种编程语言(如Python、Java等)。在本文中,Selenium通过webdriver接口与浏览器进行交互,实现页面加载、元素定位、属性操作、JavaScript执行等功能,为Web自动化测试提供了一套完整的解决方案。
WebDriver BiDi协议WebDriver BiDi (Bidirectional) 协议是Selenium 4版本引入的新特性,它使得浏览器与测试脚本之间的通信更加实时和双向。在该协议下,不仅测试脚本可以向浏览器发送指令以模拟用户操作,浏览器也能主动向测试脚本推送状态变化或事件信息,从而增强了自动化测试的响应性和灵活性。
Shadow DOMShadow DOM是现代Web组件技术中的一个重要概念,用于封装组件内部结构及样式,保证组件的独立性并减少全局命名空间污染。在Selenium中,强化对Shadow DOM的支持意味着能够更准确地定位和操作嵌入在Shadow DOM树中的元素,这对于针对采用Web组件技术构建的复杂应用进行自动化测试具有重要意义。
持续集成(CI/CD)持续集成(Continuous Integration, CI)是一种软件开发实践,强调开发人员频繁地将代码更改合并到共享主分支,并通过自动化的构建和测试确保这些更改能够顺利集成。持续部署(Continuous Deployment, CD)则是指在完成测试后,自动将软件新版本部署到生产环境。文中提到的Jenkins、Travis CI等工具可与Selenium结合,在持续集成流程中执行自动化测试,确保每一次代码变更后的快速反馈与质量保障。
视觉回归测试视觉回归测试是一种自动化测试方法,旨在检测Web界面在不同条件下的视觉效果是否符合预期。在文中提及的Applitools Eyes、PerceptualDiff等工具,它们能配合Selenium捕获页面截图,并通过算法比较前后两次截图的差异,以此判断UI界面是否有异常变化。这种测试方式对于维护跨平台、响应式设计的网站界面一致性极其重要。
延伸阅读
作为当前文章的延伸阅读,仅对当前文章有效。
在进一步探索Web自动化测试的广阔领域时,Selenium作为一款强大的工具,其功能远不止于本文所阐述的基础操作与元素定位。近期,Selenium 4版本正式发布,引入了WebDriver BiDi协议,使得浏览器与测试脚本之间的通信更为实时和高效,从而提升自动化测试的性能和稳定性。同时,新版还强化了对Shadow DOM的支持,方便开发者针对现代Web组件进行精确测试。
对于实际应用场景,Selenium结合Python、Java等编程语言可以构建复杂的自动化测试框架,如pytest-selenium、TestNG+Selenium等。而在持续集成(CI/CD)环境中,Jenkins、Travis CI等工具与Selenium的集成使用也日益普及,实现自动化测试在开发流程中的无缝衔接。
此外,为了提高测试覆盖率和效率,许多团队开始采用基于AI技术的视觉回归测试工具,如Applitools Eyes、PerceptualDiff等,它们能够与Selenium配合,通过比较页面截图来检测UI界面的变化,尤其适用于响应式设计及跨平台测试场景。
另外值得注意的是,在Web应用安全测试方面,Selenium还可以与其他安全测试工具如ZAP (Zed Attack Proxy) 结合使用,通过对网站进行爬取和模拟用户交互,帮助发现潜在的安全漏洞。
综上所述,Selenium作为Web自动化测试的核心工具,在不断迭代升级中正逐步适应更多复杂且多样化的测试需求。随着DevOps理念的深入推广和实践,熟练掌握并灵活运用Selenium将成为软件质量保障工程师必备技能之一。与此同时,关注相关领域的最新发展动态和技术趋势,将有助于我们在实际项目中更好地利用Selenium以及其他配套工具,不断提升自动化测试的效果与价值。
知识学习
实践的时候请根据实际情况谨慎操作。
随机学习一条linux命令:
getent passwd username - 从passwd数据库获取用户信息。
随便看看
拉到页底了吧,随便看看还有哪些文章你可能感兴趣。
HessianRPC在高负载下服务降级与熔断器模式保障用户体验 05-01 jQuery和TweenMax简单实用的水平手风琴特效 01-20 jquery选择国家下拉列表框插件 01-21 Sqoop在Hadoop集群中的数据传输机制及数据库迁移、收集与备份恢复应用实践 12-23 简约渔具批发牧渔企业类网站前端模板下载 11-09 基于bootstrap功能齐全的jQuery进度条插件 10-20 简约大气男性护肤产品HTML5网站模板 09-22 宽屏大气机械设备制造公司网站模板 08-13 演讲会门票销售网站模板下载 07-30 本次刷新还10个文章未展示,点击 更多查看。
经典响应式投资理财企业前端模板 06-26 基于Redis的键值对存储实现用户阅读状态跟踪与管理 06-24 Netty框架中CannotFindServerSelection异常:服务器地址配置错误与通道类型匹配详解 06-18 简洁设计公司响应式网站模板下载 05-06 绿色苗木草坪种植绿化类企业前端CMS模板下载 04-30 怎么在cmd开启mysql服务 04-15 保洁公司家庭保洁服务网站模板 03-26 SpringCloud微服务中分布式锁的死锁问题与状态一致性维护:避免循环依赖、公平锁及超时重试机制在Redisson中的实践运用 03-19 HBase性能测试与RegionServer配置、架构及数据模型调优实践:关注响应时间、并发处理能力与BlockCache优化 03-14 jquery控制radio触发事件 02-15 简约HTML5软件营销业务公司网站模板 02-09
时光飞逝
"流光容易把人抛,红了樱桃,绿了芭蕉。"