frame表单嵌套的定位

 1 frame表单嵌套的定位 2 frame标签有frameset、frame、iframe三种,frameset跟其他普通标签没有区别,不会影响到正常的定位,而frame与iframe对selenium定位而言是一样的,selenium有一组方法对frame进行操作。
 3 1.怎么切到frame中( switch_to.frame() )
 4 selenium提供了switch_to.frame()方法来切换frame
 5 switch_to.frame(reference) #reference是传入的参数,用来定位frame,可以传入id、name、index以及selenium的WebElement对象
 6 
 7 有如下HTML代码 index.html:
 8 <html lang="en">
 9     <head> <title>FrameTest</title> </head>
10     <body> <iframe src="a.html" id="frame1" name="myframe"></iframe>
11     </body>
12 </html>
13 想要定位其中的iframe并切进去,可以通过如下代码:
14 from selenium import webdriver
15 driver = webdriver.Chrome()
16 driver.switch_to.frame(0) # 1.用frame的index来定位,第一个是0
17 # driver.switch_to.frame("frame1") # 2.用id来定位
18 # driver.switch_to.frame("myframe")  # 3.用name来定位
19 # driver.switch_to.frame(driver.find_element_by_tag_name("iframe"))
20 # 4.用WebElement对象来定位
21 
22 通常采用id和name就能够解决绝大多数问题。但有时候frame并无这两项属性,则可以用index和WebElement来定位:
23 index从0开始,传入整型参数即判定为用index定位,传入str参数则判定为用id/name定位
24 WebElement对象,即用find_element系列方法所取得的对象,我们可以用tag_name、xpath等来定位frame对象
25 比如:<iframe src="myframetest.html" />
26 用xpath定位,传入WebElement对象:
27 driver.switch_to.frame(driver.find_element_by_xpath("//iframe[contains(@src,'myframe')]"))
28 
29 2.从frame中切回主文档(switch_to.default_content())
30 切到frame中之后,我们便不能继续操作主文档的元素,这时如果想操作主文档内容,则需切回主文档。
31 driver.switch_to.default_content()
32 
33 3.嵌套frame的操作( switch_to.parent_frame() )
34 有时候我们会遇到嵌套的frame,如下:
35 <html> <iframe id="frame1">
36         <iframe id="frame2" / >
37         <iframe id="frame3" / >
38     </iframe>
39 </html>
40 1.从主文档切到frame2,一层层切进去
41 driver.switch_to.frame("frame1")
42 driver.switch_to.frame("frame2")
43 2.从frame2再切回frame1,这里selenium给我们提供了一个方法能够从子frame切回到父frame,而不用我们切回主文档再切进来。
44 driver.switch_to.parent_frame() # 如果当前已是主文档,则无效果
45 有了parent_frame()这个相当于后退的方法,我们可以随意切换不同的frame,随意的跳来跳去了。
原文地址:https://www.cnblogs.com/zpdbkshangshanluoshuo/p/10442489.html