vlambda博客
学习文章列表

2.2.5 WebDriver API及对象识别技术(一)

切换Frame操作

frameset不用切,frame/iframe需要层层切

        frame标签有frameset、frame、iframe三种,frameset跟其他普通标签没有区别,不会影响到正常的定位,而frame与iframe对selenium定位而言是一样的,selenium有一组方法对frame进行操作。

一、怎么切到frame中(switch_to.frame())
  • selenium提供了switch_to.frame()方法来切换frame

switch_to.frame(reference)

reference是传入的参数,用来定位frame,可以传入id、name、index以及selenium的WebElement对象,假设有如下HTML代码 index.html:

<html> <head> <title>Iframe测试</title>    </head><body> <iframe id="frame1" name="myframe"> </iframe></body></html>

想要定位其中的iframe并切进去,可以通过如下代码:

from selenium import webdriverget_driver=webdriver.Chrome()get_driver.switch_to.frame(0) #用frame的索引来定位,第一个是0#get_driver.switch_to.frame("frame1")  #可以使用id值来定位#get_driver.switch_to.frame("myframe") #使用name来定位#get_driver.switch_to.frame(get_driver.find_element_by_id('frame1')) #使用webelement对象来定位

通常采用id和name就能够解决绝大多数问题。但有时候frame并无这两项属性,则可以用index和WebElement来定位:

  • a、index从0开始,传入整型参数即判定为用index定位,传入str参数则判定为用id/name定位;

  • b、WebElement对象,即用find_element系列方法所取得的对象,我们可以用tag_name、xpath等来定位frame对象;

举个例子:

<iframe src="mywoodframe.html" />


用xpath定位,传入WebElement对象:

get_driver.switch_to.frame(get_driver.find_element_by_xpath("//iframe(contains(@src,'wood'))"))


二、从frame中切回主文档(switch_to.default_content())

切到frame中之后,我们便不能继续操作主文档的元素,这时如果想操作主文档内容,则需切回主文档。

self.get_driver.switch_to.default_content()


三、嵌套frame的操作(switch_to.parent_frame())

有时候我们会遇到嵌套的frame,如下:

<html> <iframe id="iframe1"> <iframe id="iframe2" /> </iframe></html>


1、从主文档切到frame2,一层层切进去。

self.get_driver.switch_to.frame("iframe1")self.get_driver.switch_to.frame("iframe2")

2、从frame2再切回frame1,这里selenium给我们提供了一个方法能够从子frame切回到父frame,而不用我们切回主文档再切进来。

self.get_driver.switch_to.parent_frame()

有了parent_frame()这个相当于后退的方法,我们可以随意切换不同的frame,随意的跳来跳去了。


鼠标事件

   设置鼠标事件 (这些方法封装在ActionChains类中)

from selenium.webdriver.common.action_chains import ActionChains
  • context_click()  右击

  • double_click()   双击

  • drag_and_drop()  拖动

  • move_to_element()  鼠标悬停在一个元素上

  • click_and_hold()   按下鼠标左键在一个元素上

注意:在引用鼠标模块时容易出现的两个错误:
  • 1)ActionChains(驱动器对象) 容易将驱动器对象漏掉

  • 2)在调用完相关操作后,没有添加执行步骤即perform()

context_click() 右击
#引入ActionChains类
from selenium.webdriver.common.action_chains import ActionChains
....
#定位到要右击的元素
right =driver.find_element_by_xpath("xx")
#对定位到的元素执行鼠标右键操作ActionChains(driver).context_click(right).perform()
....
drag_and_drop()  拖动
from selenium.webdriver.common.action_chains import ActionChains
...
#定位元素的原位置
element = driver.find_element_by_name("xxx")
#定位元素要移动到的目标位置
target =  driver.find_element_by_name("xxx")
#执行元素的移动操作ActionChains(driver).drag_and_drop(element,target).perform()
move_to_element()   鼠标悬停
from selenium.webdriver.common.action_chains import ActionChains
...
#定位元素的原位置
element = driver.find_element_by_name("xxx")
#定位元素要移动到的目标位置
target =  driver.find_element_by_name("xxx")
#执行元素的移动操作ActionChains(driver).drag_and_drop(element,target).perform()

键盘事件

设置键盘事件(这些方法封装在Keys类中)

from selenium.webdriver.common.keys import Keys   #设置键盘事件
键盘删除事件
driver.find_element_by_id('kw').send_keys('Selenium2.00')
time.sleep(5)
driver.find_element_by_id('kw').send_keys(Keys.BACKSPACE)
空格事件
driver.find_element_by_id('kw').send_keys(Keys.SPACE)
time.sleep(5)
driver.find_element_by_id('kw').send_keys('Selenium2.00')
全选事件
driver.find_element_by_id('kw').send_keys(Keys.CONTROL,'a')
time.sleep(3)
复制事件
driver.find_element_by_id('kw').send_keys(Keys.CONTROL,'c')
time.sleep(3)
driver.get(second_url='http://www.hao123.com')
粘贴事件
driver.find_element_by_id('search-input').send_keys(Keys.CONTROL,'v')
time.sleep(2)
driver.find_element_by_class_name('button-hook').click()

思考

Q:键盘事件是否可以解决下拉列表框的选择,如何实现?
R:可以,可以通过上下键然后乘以随机产生的数,即可完成向上或者向下选择;例如:

get_driver.find_element_by_name("area").send_keys(Keys.ARROW_DOWN* 3)