元素定位的几种方式:

(1)driver.find_element_by_id("idname")

(2)driver.find_element_by_name("name")

(3)driver.find_element_by_class_name("classname")

(4)driver.find_element_by_tag_name("tagname")——tag:<div><input><a>

(5)driver.find_element_by_link_text("linkurl")——link

(6)driver.find_element_by_partial_link_text("")——link里面的文本

(7)driver.find_element_by_xpath("  ")

——eg:find_element_by_xpath(“//input[@id='kw']/span”)

——//表示当前页面某个目录下,input表示定位元素的标签名,[@id='kw']表示这个元素的id属性值等于kw,然后再定位到下一级的span

——与css_selector 的区别在于,同级用[@xxxx]来表示,下级用/,@可能是表id,name,class,*元素的任意属性值都可以用,比如,@maxlength='100',@autocomplete='off',@type='submit',

(8)driver.find_element_by_css_selector("")——可以内含classname,idname,*,元素标签,父子元素>,紧接着的元素+,attribute

——eg:find_element_by_css_selector(".s_ipt")//classname——(“#idname”)——(“span>input”)父子——(“[name='kw']”)另一种写法——(“[type='submit']”)——("*")所有元素

(9)用By来定位元素,相当于另外一套写法

driver.find_element(By.ID,'kw')……NAME,CLASS_NAME,XPATH,PARTIAL_LINK_TEXT

====================================================

举个例子:

driver=webdriver.chrome()

file_path = “www.baidu.com”

driver.get(file_path)

==================================================

控制浏览器

(1)driver.get("url")

(2)driver.quit()

(3)driver.close()

浏览器有两个tab,此时close方法就只能关闭driver正在操作的窗口而不能关闭浏览器了。

(1)控制浏览器窗口大小

driver.set_window_size()

driver.maximize_window()

(2)控制浏览器后退、前进

driver.back()

driver.forward()

(3)模拟浏览器刷新

driver.refresh()

(4)简单元素操作

clear()//清除文本

send_keys()//模拟按键输入

click() //单击元素

webElement接口常用方法

submit()

size

text

get_attribute(name)

is_displayed()

-------------------------------------

driver.find_element_by_id("idname").click()

driver.find_element_by_id("idname").size

driver.find_element_by_id("idname").text

driver.find_element_by_id("idname").get_attribute('type')

driver.find_element_by_id("searchbox").submit()

鼠标事件封装在ActionChains中

右击 context_click(xxx)

双击double_click()

拖动drag_and_drop()

鼠标悬停move_to_element()

right_click= driver.find_element_by_id("xx")

AcitonChains(driver).context_click(right_click).perform()

perform()执行所有ActionChains中的存储的行为,理解为整个操作的提交动作

================================================================

键盘事件

send_keys("text")

send_keys(Keys.TAB)

send_keys(Keys.CONTROL,'a')=====ctrl+A

driver.find_element_by_id("idname").send_keys(Keys.TAB)

=================================================================

获取验证信息

通常有:title, URL, text

title=driver.title

now_url=driver.current_url

text=driver.find_element_by_id(‘idname’).text

===================================================================

设置元素等待

WebDriver 提供了两种类型的等待,显示等待和隐式等待

显示等待:WebDriverWait()

————WebDriverWait(driver,timeout,poll_frequency=0.5,ignored_exceptions=None)

timeout:最长超过事件,默认以秒单位

poll_frequency:检测的时间间隔,默认为0.5s

ignored_exceptions:超时候的异常信息,默认情况下抛NoSuchElementException异常

until(method,message='xxxx')

————eg:

————element= WebDriverWait(driver,5,0.5).until(expected_conditions.presence_of_element_located((By.ID,"kw")))

————element.send_keys("hhh")

-----------------------------------------------------------------------------------------

预期条件判断方法见表格p97

-------------------------------------------------------------------------------------------

隐式等待:implicitly_wait(10)超过10s还未被加载,抛出nosuchelementexception

显示等待才:until,until_not

is_displayed()

=======================================================

休眠方法

sleep(5)

=======================================================

定位一组元素

eg:选择页面上所有的tagname为input的元素

inputs=driver.find_element_by_tag_name('input')

过滤出type为checkbox的元素,单击勾选

for i in inputs:

  if i.get_attribute('type')=='checkbox'

    i.click()

    time.sleep(1)

=========================================================

多表单切换

switch_to.frame()讲当前定位的主体切换到frame/iframe 表单的内嵌页面中,参数可以取表单的id或name

switch_to.window()跳回到最外层的页面

==========================================================

多窗口切换

switch_to.window()实现在不同的窗口切换

获得当前窗口句柄:

c_window=driver.current_window_handle

获得当前打开的所有窗口的句柄

all_window=driver.window_handles

======================================================================

警告窗处理

switch_to_alert()方法定位到alert/confirm/prompt 然后使用text,accept,dismiss ,send_keys等方法进行操作

text:返回当中的文字信息

accept():接受现有警告框

dismiss():解散现有警告框

send_keys(KeysToSend)发送文本至警告框.讲文本发送至警告框

driver.switch_to_alert().accept()

driver.quit()

selenium_UI自动化——篇1(基础)的更多相关文章

  1. Membership三步曲之入门篇 - Membership基础示例

    Membership 三步曲之入门篇 - Membership基础示例 Membership三步曲之入门篇 -  Membership基础示例 Membership三步曲之进阶篇 -  深入剖析Pro ...

  2. swift开发多线程篇 - 多线程基础

    swift开发多线程篇 - 多线程基础 iOS 的三种多线程技术 (1)NSThread  使用NSThread对象建立一个线程非常方便 但是!要使用NSThread管理多个线程非常困难,不推荐使用 ...

  3. [转]Membership三步曲之入门篇 - Membership基础示例

    本文转自:http://www.cnblogs.com/jesse2013/p/membership.html Membership三步曲之入门篇 - Membership基础示例   Members ...

  4. iOS开发UI篇—Button基础

    iOS开发UI篇—Button基础 一.简单说明 一般情况下,点击某个控件后,会做出相应反应的都是按钮 按钮的功能比较多,既能显示文字,又能显示图片,还能随时调整内部图片和文字的位置 二.按钮的三种状 ...

  5. iOS开发基础篇-Button基础

    一.简单介绍  UIButton 的功能:响应用户操作.显示文字.显示图片.调整内部图片和文字的位置. 二. UIButton 的状态  UIControlStateNormal :普通状态,为默认情 ...

  6. 【0728 | 预习】第三篇 Python基础

    第三篇 Python基础预习 Part 1 变量 一.什么是变量? 二.为什么要有变量? 三.定义变量 四.变量的组成 五.变量名的命名规范 六.变量名的两种风格 Part 2 常量 Part 3 P ...

  7. 前端第二篇---前端基础之CSS

    前端第二篇---前端基础之CSS 目录 一.css介绍 二.css语法 三.css的几种引入方式 四.css选择器 五.css属性相关 六.盒子模型 拓展 一.css介绍 CSS(Cascading  ...

  8. 前端第三篇---前端基础之JavaScript

    前端第三篇---前端基础之JavaScript 一.JavaScript概述 二.JavaScript的基础 三.词法分析 四.JavaScript的内置对象和方法 五.BOM对象 六.DOM对象 七 ...

  9. 前端第四篇---前端基础之jQuery

    前端第四篇---前端基础之jQuery 一.jQuery介绍 二.jQuery对象 三.jQuery基础语法 四.事件 五.动画效果 六.补充each 一.jQuery简介 1.jQuery介绍 jQ ...

随机推荐

  1. HDU 3861 The King’s Problem(tarjan缩点+最小路径覆盖:sig-最大二分匹配数,经典题)

    The King’s Problem Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Other ...

  2. ansible role 理解

    1.roles意为角色,主要用于封装playbook实现复用性.在ansible中,roles通过文件的组织结构来展现.

  3. defaultdict - update - pymysql

    defaultdict 的例子 使用list作为default_factory,他很容易的将一个以键值形式表现的序列分组成一个字典列表 >>> s = [('yellow', 1), ...

  4. 写个定时任务更新svn

    最近学了点shell编程,寻思锻炼下写一个.平常你学习或者看别人讲,自己不练习肯定不行,基本上一动手准出错哈哈.等自己去实践,才会知道哪里有问题,哪里容易出错,哪里要注意什么的. 因为我们每个人有自己 ...

  5. js中常见继承方式

    1.原型模式 function Father(){ this.property = true; } Father.prototype.getValue = function(){ return thi ...

  6. POJ1080

    一道字符串DP,然而不需要状压之类的玄学操作 题目大意:给你两个串,由'A','C','G','T'组成,现在你可以在这两个串中的某些位置插入'-',最终要使得它们的长度相等 给出两个字符匹配时的匹配 ...

  7. python 回溯法 子集树模板 系列 —— 6、排课问题

    问题 某乡村小学有六个年级,每个年级有一个班,共六个班. 周一到周五,每天上6节课,共计30节课. 开设的课程 一年级:语(9)数(9)书(2)体(2)美(2)音(2)德(2)班(1)安(1) 二年级 ...

  8. Ubuntu16.04LTS +Qt+boost1.66编译错误:consuming_buffers.hpp: parse error in template argument list

    升级gcc版本至 6 以上.. 安装gcc-6系列与安装boost (Ubuntu16.04LTS)

  9. JavaScript快速入门-ECMAScript本地对象(Number)

    Number 对象是原始数值的包装对象. 创建一个Number对象:var myNum=new Number(value); 注意: 1.参数 value 是要创建的 Number 对象的数值,或是要 ...

  10. PWM输出

    PWM(Pulse Width Modulation),脉冲宽度调制. 脉冲的频率由ARR控制,ARR越大频率越小:占空比由CCRx控制,CCRx越小占空比越大. 捕获/比较通道的输出部分(通道1) ...