• Selenium-python 之 frame定位元素


    定位元素时经常会出现定位不到元素,这时候我们需要观察标签的上下文,一般情况下这些定位不到的元素存放在了frame或者放到窗口了,只要我们切入进去就可以很容易定位到元素。

    处理frame时主要使用到switch_to.frame()(切入frame也可以些写成switch_to_frame,不过这个已经用的很少了)和switch_to_default_content()两个方法,一个主要是切入到iframe里面,一个是切换到主文档中,一般情况这两个要配合着用,切进去以后操作完成元素以后,就要在切回到主文档,避免一些其他的错误。

    switch_to.frame()  #如果frame 中有name和id属性就直接使用id或者name进行定位,如果没有id和name属性,可以通过find_element_by_xpath(或者其他定位)方法定位到这个iframe元素,然后把这个元素传进去。

    当有两个frame时,需要先进入父frame,再进入子frame中,对子frame中的元素操作后,需要先切回到父frame中,再回到最外面的主文档区域。

    代码举例:

    以禅道测试人员登录后进行确认BUG为例

    #进入BUG详情页后进入确认BUG页面
    driver.find_element(By.XPATH,"//a[contains(@href,'/zentao/bug-confirmBug')]").click()
    confirm_iframe=driver.find_element(By.XPATH,"//iframe[@id='iframe-triggerModal']") #定义一个确认BUG的frame元素对象
    driver.switch_to.frame(confirm_iframe) #进入frame
    time.sleep(1)
    driver.find_element(By.XPATH,"//div[@id='assignedTo_chosen']").click() ##对frame中的元素操作,此处操作下拉框
    driver.find_element(By.XPATH,"//li[@title='K:开发001']").click() #下拉框输入值
    beizhu_iframe=driver.find_element(By.XPATH,"//iframe[@class='ke-edit-iframe']") ##进入备注子frame中,再定义一个frame对象
    driver.switch_to.frame(beizhu_iframe) #进入子frame
    driver.find_element(By.XPATH,"//body[@class='article-content']").send_keys("确认问题") #对子frame的元素进行操作
    driver.switch_to.parent_frame() #切出子frame,回到父frame,才能对父frame上的元素再次操作
    driver.find_element(By.XPATH,"//button[@type='submit'][@class='btn btn-wide btn-primary']").click() #对父frame上的元素进行操作
    time.sleep(2)
    driver.switch_to.default_content() ##跳出父iframe,回到最外面的HTML
    time.sleep(2)
    ##禅道退出,对主文档上的元素进行操作
    driver.maximize_window()
    driver.find_element(By.XPATH, "//span[@class='user-name']").click()
    driver.find_element(By.XPATH, "//div[1]/div/div/div/ul/li/ul/li[13]/a").click()
    time.sleep(1)
  • 相关阅读:
    确保消息产生前数据库操作已提交
    信息披露和公司简介总结
    1、清空所有,给当前添加/2、清空上一个,给当前添加。
    不能作为判断条件的:
    excel表格 函数功能
    一种ui app写法
    正则中使用变量及数组去重的方法
    鼠标锁定(消失),进入无限滚动状态
    transform 的旋转 ,3d效果,要添加3d效果的父级加上景深perspective。 3d效果的容器加上 transform-style:preserve-3d。
    rem布局,在用户调整手机字体大小/用户调整浏览器字体大小后,布局错乱问题
  • 原文地址:https://www.cnblogs.com/123anqier-blog/p/12683078.html
Copyright © 2020-2023  润新知