iframe\句柄\鼠标键盘是一些比较特殊的事件,需要特殊处理

目录

1、iframe

2、句柄(handle)

3、鼠标键盘

1、iframe

iframe 是内嵌的网页元素,也可以说是内嵌的框架,我们需要先切换到iframe上面,才能对元素进行操作,若需要再操作不在iframe上的元素需要切换topwindow

001、判断是否有iframe

至于在不在iframe上面,通过firepath看一下是不是topwindow,如果不是就是在iframe上面

iframe一般有2种,一种是有id,一种没有id

002、有id的通过id来定位

driver.switch_to_frame(“id属性值”)

  

003、无id的通过tag name定位,然后切换

m=driver.find_element_by_tag_name(“iframe”)
driver.switch_to_frame(m)

特别的,有多个无id的iframe,可通过索引来定位

m=driver.find_element_by_tag_name("iframe")[0]
switch_to.iframe(m)

004、操作完iframe上的元素后,需要操作不在iframe上的元素,需要切回topwindow,再操作

driver.switch_to_default_content()

 特别的,有多个iframe,需要一层一层的定位进去;需要切换回上一个iframe,可以用

driver.switch_to.parent_frame() 

注:switch_to_frame()上面会有横线,可以写成driver.switch_to.frame(),就没问题了

2、句柄(handle)

再调试的时候,如果点开的是一个链接,则可以手动拖动下,看他是否会重新打开一个窗口,如果会,则他就是另一个句柄了。浏览器窗口的属性,用句柄来识别

001、打印当前句柄

m=driver.current_window_handle
print m

002、获取所有句柄

m=driver.window_handles
print m
'''获取第二个句柄’‘’
print m[1]

003、如果不等于当前句柄就切换

h = driver.current_window_handle
all_h = driver.window_handles
for i in all_h:
if i!=h;
driver.switch_to.window(i)

 

driver.switch_to.window(h) #切换回首页

3、鼠标键盘

001、键盘事件

一般在浏览器中会有一个输入完就回车的动作submit()

driver.find_element_by_name("password").sendkeys()
driver.find_element_by_name("password").submit()

如果submit()提交不了的话,可以导入键盘事件模块

导入:

from selenium.webdriver.common.keys import Keys

键盘操作有单个输入和组合输入

单个输入

如enter:send_keys(keys,ENTER)

制表键 Tab: send_keys(Keys.TAB)

空格键:send_keys(Keys.SPACE)

组合输入

如复刢 Ctrl+C:send_keys(Keys.CONTROL,'c') ,其他组合键类似

可以将剪切、复制、粘贴组合使用。

002、鼠标事件

导入:

from selenium.webdriver.common.action_chains import ActionChains

 鼠标事件后,都需要有一个执行的动作perform(),最常见的鼠标动作就是悬停move_to_element()

a、悬停事件

mouse = driver.find_element_by_link_text("设置")
ActionChains(driver).move_to_element(mouse).perform()

b、拖动事件

从源路径将鼠标滑动拖到目标路径

source = driver.find_element_by_id("xxx")
target = driver.find_element_by_id("xxx")
ActionChains(driver).drag_and_drop(source, target).perform()

  

  

UI自动化之特殊处理一(iframe\句柄\鼠标键盘)的更多相关文章

  1. python UI自动化之切换iframe

    python+selenium写UI自动化的时候,经常会遇到需要切换iframe的情况,这里介绍几种切换iframe的方式 1.使用id定位 driver.switch_to.frame(" ...

  2. ui自动化笔记 selenium_webdriver,ui自动化框架(web)

    Selenium学习笔记 selenium webdriver是业界公认ui自动化测试的标准,其封装的api可以对浏览器的任何地方进行操作 selenium2.0和selenium3.0的区别? 3. ...

  3. Python—UI自动化完整实战

    实战项目 均来源于互联网 测试报告2017年11月29日优化后的测试报告:https://github.com/defnngj/HTMLTestRunner 1.项目概述: 本实战已126邮箱为例子进 ...

  4. robot framework UI自动化之登录

    前面已写环境的搭建,接下来就可以直接进行UI自动化的编写工作了 目录 1.准备工作 2.了解定位 3.一个登录案例 1.准备工作 第一步:需要使用chrome浏览器来测试,因此首先要有一个驱动,下载好 ...

  5. UI自动化之8种基础定位

    UI自动化的核心在于定位 目录 1.8种基础定位方法 2.xpath定位 3.css定位 4.多组元素 1.8种基础定位方法 driver.find_element_by_id() #id定位 dri ...

  6. UI自动化处理文件上传

    UI自动化处理文件上传 import win32guiimport win32con def set_uploader(self, file_path): sleep(2) self.file_pat ...

  7. 基于python2+selenium3+pytest4的UI自动化框架

    环境:Python2.7.10, selenium3.141.0, pytest4.6.6, pytest-html1.22.0, Windows-7-6.1.7601-SP1 特点:- 二次封装了s ...

  8. Python结合Pywinauto 进行 Windows UI 自动化

    转:Python结合Pywinauto 进行 Windows UI 自动化 https://blog.csdn.net/z_johnny/article/details/52778064 说明:Pyw ...

  9. UI自动化,你值得拥有

    去年春节联欢晚会,为了那张“敬业福”,全家都卯足了劲儿“咻一咻”,连节目都顾不上看了.当时我就想,要是能自动化该多好,不停点击屏幕,屏幕不疼手还疼呢,何况还不好分心,生怕错过了“敬业福”.玩“咻一咻” ...

随机推荐

  1. kafka复习(2)

    一.简介 --------------------------------------- 1.kafka是一个分布式的.可分区的.可复制的消息系统.它提供了消息系统的功能,但是有自己独特的设计. 2. ...

  2. JavaScript的循环结构和经典题目

    一.JS中的循环结构 循环结构的执行步骤1.声明循环变量:2.判断循环条件;3.执行循环体操作:4.更新循环变量:5.然后循环执行2-4,直到条件不成立,跳出循环. while循环()中的表达式,运算 ...

  3. 基于Nginx+nginx-rtmp-module+ffmpeg搭建rtmp、hls流媒体服务器(二)

    前言 Nginx-rtmp-module插件针对RTMP协议中一些命令,实现了事件通知和exec外部脚本处理.这里我通过一个简单的SpringBoot项目和Python代码,快速搭建一个HTTP服务来 ...

  4. losetup - 设 定 与 控 制 环回设备

    总览 SYNOPSIS losetup [ -e encryption ] [ -o offset ] loop_device file losetup [ -d ] loop_device 描述 l ...

  5. 关于阅读Struts2部分拦截器源码的记录

    Struts2中的拦截器在ActionInvocation对象的invoke()方法中执行. ActionInvocation对象从配置文件中读取Interceptor对象,加入到自己的存取拦截器的容 ...

  6. 初学Git——命令总结

    首先,感谢廖雪峰老师制作的Git教程:https://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b0 ...

  7. Fokker–Planck equation

    Fokker–Planck equation:https://en.wikipedia.org/wiki/Fokker%E2%80%93Planck_equation 随机微分方程:https://e ...

  8. codeforces 108D Basketball Team(简单组合)

    D. Basketball Team time limit per test 2 seconds memory limit per test 256 megabytes input standard ...

  9. ESP8266-让灯闪烁

    例子一:让板子上的LED_BUILTIN灯进行闪烁 void setup() { pinMode(LED_BUILTIN,OUTPUT); } void loop() { digitalWrite(L ...

  10. vue的.sync 修饰符

    很多时候,我们会对 prop (父子组件传递数据的属性) 进行“双向绑定” 在vue 1.x 中的 .sync 修饰符所提供的功能.当一个子组件改变了一个带 .sync 的prop的值时,这个变化也会 ...