说明

Webdriver API详解,基于python3,unittest框架,driver版本和浏览器自行选择。 本内容需要对python3的unittest框架有一个简单的了解,这里不再赘述,不了解的同学自己百度了解一下就可以了。废话不多说直接进入正题!

简单代码框架模板

 from selenium import webdriver
import unittest class MyTest(unittest.TestCase): def setUp(self):
self.driver = webdriver.Chrome()
8
def testFunc(self): # 后面所有的实例代码直接替换这个函数或者直接在代码中添加函数即可
pass
def tearDown(self):
self.driver.quit() if __name__ == '__main__':
unittest.main()

①访问某个网址

目的:打开指定网址

测试地址:https:www.baidu.com

调用API实例代码

     def testOpenBaiduUrl(self):
'''
1.访问具体地址
:return:
'''
baseUrl = 'https://www.baidu.com/'
baseTitle = '百度一下'
self.driver.get(baseUrl)# 访问百度的网址
currTitle = self.driver.title # 获取当前页面的标题
self.assertIn(baseTitle, currTitle, msg='页面跳转失败') # 断言

②网页的前进,后退和刷新页面

目的:模拟浏览器的前进和后退功能

测试地址:

https://www.sogou.com;https://www.baidu.com

调用API实例代码

     def testBackForwardRefresh(self):
'''
前进,后退,刷新当前页面
:return:
'''
baseBaiduUrl = 'https://www.baidu.com/'
baseSogouUrl = 'https://www.sogou.com/'
self.driver.get(baseBaiduUrl)
self.driver.get(baseSogouUrl)
self.driver.back() # 后退
print(self.driver.current_url)
self.driver.forward() # 前进
print(self.driver.current_url)
self.driver.refresh() #刷新页面

③操作浏览器窗口位置

目的:窗口最大化,获取浏览器位置坐标,设置浏览器窗口位置

测试地址:https://www.baidu.com

调用API实例代码

     def testWindow(self):
'''
窗口最大化,获取当前窗口的位置,设置当前窗口的位置
:return:
'''
baseBaiduUrl = 'https://www.baidu.com/'
self.driver.get(baseBaiduUrl)
position = self.driver.get_window_position() # 获取当前窗口的位置坐标
print('当前窗口的横坐标为{}'.format(position['x']))
print('当前窗口的纵坐标为{}'.format(position['y']))
self.driver.set_window_position(400, 200) # 设置窗口的位置
print('设置后的窗口的位置坐标:{}'.format(self.driver.get_window_position()))
self.driver.maximize_window() #窗口最大化

④操作浏览器窗口的大小

目的:获取当前窗口的大小,设置当前窗口的大小

测试地址:https://www.baidu.com

调用API实例代码

     def testWindowSize(self):
'''
获取当前窗口的大小,设置当前窗口的大小
:return:
'''
baseBaiduUrl = 'https://www.baidu.com/'
self.driver.get(baseBaiduUrl)
#获取当前窗口的大小
windowSize = self.driver.get_window_size('current')
print('当前窗口的宽为{}'.format(windowSize['width']))
print('当前窗口的高为{}'.format(windowSize['height']))
#设置当前窗口的大小
self.driver.set_window_size(width=200, height=400, windowHandle='current')
print(self.driver.get_window_size('current'))

⑤获取当前页面的Title属性值

目的:获取百度页面的title属性值

测试地址:https://www.baidu.com

调用API实例代码

  def testGetBaiduTitle(self):
'''
获取页面的title属性值
:return:
'''
baseBaiduUrl = 'https://www.baidu.com/'
self.driver.get(baseBaiduUrl)
bdTitle = self.driver.title # 获取百度页面的title属性值
print(bdTitle)
self.assertEqual(bdTitle,'百度一下,你就知道',msg='页面title不正确'

⑥获取页面的url地址与页面源码

目的:获取百度页面的地址与源码

测试地址:https://www.baidu.com

调用API实例代码

     def testGetBaiduUrlSourceCode(self):
'''
获取页面的url和页面源码
:return:
'''
baseBaiduUrl = 'https://www.baidu.com/'
self.driver.get(baseBaiduUrl)
bdUrl = self.driver.current_url # 获取当前页面的url地址
print(bdUrl)
self.assertEqual(bdUrl,'https://www.baidu.com/',msg='当前页面url不正确')
sourceCode = self.driver.page_source # 获取当前页面的源码v
print(sourceCode)

⑦获取与切换浏览器窗口句柄

目的:获取当前窗口句柄,获取所有窗口句柄,句柄之间切换

测试地址:https://www.baidu.com

调用API实例代码

     def testGetwindowHandle(self):
'''
获取当前页面的句柄,切换窗口
:return:
'''
import time
baseBaiduUrl = 'https://www.baidu.com/'
self.driver.get(baseBaiduUrl)
self.driver.maximize_window()
# 获取当前窗口句柄
current_handle = self.driver.current_window_handle
print(current_handle)
#百度搜索框输入selenium并点击百度一下
self.driver.find_element_by_id('kw').send_keys('selenium')
self.driver.find_element_by_id('su').click()
time.sleep(3)
#点击selenium的百度百科连接
self.driver.find_element_by_partial_link_text('百度百科').click()
#获取所有窗口的句柄
all_handles = self.driver.window_handles
print(all_handles)
#打印新窗口的句柄
print(self.driver.window_handles[-1])
for handle in all_handles:
# 切换到新的窗口
if handle != current_handle:
self.driver.switch_to.window(handle)
self.driver.find_element_by_link_text('元素硒的英文名').click()
# 返回到原来的窗口
self.driver.switch_to.window(current_handle)
sendKeys = self.driver.find_element_by_id('kw')
sendKeys.clear()
sendKeys.send_keys('python')

⑧获取页面元素的基本信息

目的:获取页面某个元素tagname,size,text

测试地址

https://www.baidu.com

     def testGetElementInfo(self):

         baseBaiduUrl = 'https://www.baidu.com/'
self.driver.get(baseBaiduUrl)
self.driver.maximize_window()
element = self.driver.find_element_by_xpath("//a[text()='新闻']")
print('我的tag_name是{},我的text是{},我的size是{}'.format(element.tag_name,element.text,element.size))

输出:我的tag_name是a,我的text是新闻,我的size是{'height': 24, 'width': 26}

⑨获取元素的CSS属性值

目的:获取百度输入框的CSS属性值

测试地址

https://www.baidu.com

     def testGetCssInfo(self):
'''
获取元素的css属性值
:return:
'''
baseBaiduUrl = 'https://www.baidu.com/'
self.driver.get(baseBaiduUrl)
self.driver.maximize_window()
element = self.driver.find_element_by_id('kw')
print(element.value_of_css_property('height'))# 获取搜索框的高
print(element.value_of_css_property('width'))# 获取搜索框的宽
print(element.value_of_css_property('font-family'))# 获取搜索框输入的字体

输出:

22px
500px
arial

⑩输入框输入指定内容,清空输入框中的内容

目的:百度输入框输入python并清空内容

测试地址

https://www.baidu.com

  def testInputClear(self):
'''
获取元素的css属性值
:return:
'''
import time
baseBaiduUrl = 'https://www.baidu.com/'
self.driver.get(baseBaiduUrl)
self.driver.maximize_window()
element = self.driver.find_element_by_id('kw')
element.send_keys('python')# 输入指定内容
time.sleep(5)
element.clear() # 清空输入框

总结

以上共10个实例,涉及到API有get(), send_keys(),clear(),text,maximize_window(),current_url, back(), forword(), refresh(), get_window_position(), get_window_size(), set_window_position, title, current_window_handle, window_handles, value_of_css_property()等十几个方法,都是实际工作中会经常会用到的,希望对大家有所帮助,后续会陆续更新其他的API用法。

Webdriver之API详解(1)的更多相关文章

  1. Webdriver之API详解(3)

    前言 前两篇API链接 https://www.cnblogs.com/linuxchao/p/linuxchao-selenium-apione.html https://www.cnblogs.c ...

  2. Webdriver之API详解(2)

    前言:今天继续上一篇文章https://www.cnblogs.com/linuxchao/p/linuxchao-selenium-apione.html分享selenium' webdriver ...

  3. Java 8 Stream API详解--转

    原文地址:http://blog.csdn.net/chszs/article/details/47038607 Java 8 Stream API详解 一.Stream API介绍 Java8引入了 ...

  4. jqGrid APi 详解

    jqGrid APi 详解 jqGrid皮肤 从3.5版本开始,jqGrid完全支持jquery UI的theme.我们可以从http://jqueryui.com/themeroller/下载我们所 ...

  5. hibernate学习(2)——api详解对象

    1   Configuration 配置对象 /详解Configuration对象 public class Configuration_test { @Test //Configuration 用户 ...

  6. 网络编程socket基本API详解(转)

    网络编程socket基本API详解   socket socket是在应用层和传输层之间的一个抽象层,它把TCP/IP层复杂的操作抽象为几个简单的接口供应用层调用已实现进程在网络中通信. socket ...

  7. 转】Mahout推荐算法API详解

    原博文出自于: http://blog.fens.me/mahout-recommendation-api/ 感谢! Posted: Oct 21, 2013 Tags: itemCFknnMahou ...

  8. dom4j api 详解--XPath 节点详解

    dom4j api 详解 http://871421448.iteye.com/blog/1546955 XPath 节点 http://www.w3school.com.cn/xpath/xpath ...

  9. 百度地图API详解之事件机制,function“闭包”解决for循环和监听器冲突的问题:

    原文:百度地图API详解之事件机制,function"闭包"解决for循环和监听器冲突的问题: 百度地图API详解之事件机制 2011年07月26日 星期二 下午 04:06 和D ...

随机推荐

  1. 如何快速掌握DDT数据驱动测试?

    1.前言 (网盗概念^-^)相同的测试脚本使用不同的测试数据来执行,测试数据和测试行为完全分离, 这样的测试脚本设计模式称为数据驱动.(网盗结束)当我们测试某个网站的登录功能时,我们往往会使用不同的用 ...

  2. 微擎where范围查询in

    where sale_time in($todayStart,$todayEnd)

  3. HTML5+CSS3入门学习(一)——HTML5

    什么是 HTML5? HTML5 将成为 HTML.XHTML 以及 HTML DOM 的新标准. HTML 的上一个版本诞生于 1999 年.自从那以后,Web 世界已经经历了巨变. HTML5 仍 ...

  4. 经典排序算法 — C#版本(中)

    归并排序比较适合大规模得数据排序,借鉴了分治思想. 归并排序原理 自古以来,分久必合合久必分. 我们可以这样理解归并排序,分-分到不能分为止,然后合并. 使用递归将问题一点一点分解,最后进行合并. 分 ...

  5. 【机器学习】--xgboost从初识到应用

    一.前述 在 Kaggle 的很多比赛中,我们可以看到很多 winner 喜欢用 xgboost,而且获得非常好的表现,今天就来看看 xgboost 到底是什么以及如何应用.Gradient boos ...

  6. ACache【轻量级的开源缓存框架】

    版权声明:本文为HaiyuKing原创文章,转载请注明出处! 前言 官方介绍 ASimpleCache 是一个为android制定的 轻量级的 开源缓存框架.轻量到只有一个java文件(由十几个类精简 ...

  7. cocos creator主程入门教程(五)—— 日志系统

    五邑隐侠,本名关健昌,10年游戏生涯,现隐居五邑.本系列文章以TypeScript为介绍语言. 这一篇介绍日志系统的设计.一般我们开发一个demo,只会简单的用cocos提供的cc.log打印下日志, ...

  8. SpringCloud-Eureka注册与发现

    这两年可以说微服务是热词,也是新领域,学习的成本也较高,基础东西太多比如什么Dubbo,zookeeper,Springboot等等.Dubbo也是实现服务治理又是阿里出的一套开源RPC框架,但是Sp ...

  9. 由于服务主机:DCOM服务进程占用过多CPU,导致系统卡死

    最近在使用电脑的时候,总是出现电脑死机,而且鼠标也是经常卡在那里不动了,开始以为是鼠标的问题,还换了个鼠标(飙泪中),这还是一个血的教训啊!!!之后打开任务管理器发现CPU占用已经达到100%,而且一 ...

  10. 命令行操作mysql 未完待续......

    复制数据表 create table 新表 like 旧表: 删除表中某个字段 alter table 表名 drop column 字段; 例子: alter table news_apply_lo ...