selenium中元素定位正确但是操作失败,6种解决办法全搞定

selenium元素定位正确但是操作失败的原因无外乎以下4种:

01 页面没加载好

解决方法:添加等待方法,如:time.sleep()

02 页面提交需要等待给数据后台

解决方法:添加等待方法,如:time.sleep()

03 浏览器没有以最大化方式打开,导致元素被隐藏,定位不到

解决方法:

将网页最大化:driver.maximize_window()

如果屏幕比例固定,分辨率有限,通过网页最大化也没办法解决的话,可以通过执行JS方法来实现。

browser.execute_script('window.scrollBy(200,0)')  #此处(200,0)为网页偏移坐标,200为横坐标,0为纵坐标

#window.scrollBy()为JS方法#

04 网页中存在多个frame框架,所定位的元素不在当前frame中

网页中存在多个frame框架,所定位的元素不在当前frame中。所以尽管元素明明看起来是定位正确的,但是点击无效。

对于嵌套多个frame的页面,操作时需要层层跳转,跳到元素所在的frame。

frame标签有frameset、frame、iframe三种,frameset与其他普通标签一样,不会影响元素的定位;而frame与iframe的切换方法是一样的。

解决方法:可以利用selenium中的switch_to.frame()方法来实现frame之间的跳转。

具体操作如下:

1.如何对frame进行切换?

利用switch_to.frame()方法来进行切换。

switch_to.frame(reference)

reference是传入的参数,用来定位frame,可以是id,name,tag name等。假设有下面HTML代码:

<html>

<head>

    <title>FrameTest</title>

</head>

<body>

<iframe src="myframe.html" id="frame1" name="myframe"></iframe>

</body>

</html>

则想要切换到上述iframe的方法有:

driver.switch_to.frame(0)  #用frame的index定位,第一个是0

driver.switch_to.frame("frame1")  #用frame的id来定位

driver.switch_to.frame("myframe") #用name来定位

driver.switch_to.frame(driver.find_element_by_tag_name("iframe"))  #用iframe对应的tag name来定位

driver.switch_to_frame(driver.find_element_by_xpath("//iframe[contains(@src,'myframe')]"))  #利用xpath来定位

2.如何从子frame切换回主文档?

切换到子frame后就无法再对主文档元素进行操作了,所以要切换回主文档。方法为:driver.switch_to.default_content()

driver.switch_to.default_content()

3.多层frame如何切换?

如果有多层frame要逐层进行切换,例如下列多个frame嵌套的HTML代码:

<html>

    <iframe id="frame1">

        <iframe id="frame2" / >

    </iframe>

</html>

(1)从主文档切换到frame 2:

driver.switch_to.frame('frame1')  #先从主文档切换到frame1

driver.switch_to.frame('frame2')  #再从frame1切换到frame2

(2)从frame2切回到frame1:

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

driver.switch_to.parent_frame()  # 如果当前已是主文档,则无效果

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

总结下,遇到frame跳转问题,利用以下三个方法便可以搞定:

driver.switch_to.frame(reference)

driver.switch_to.parent_frame()

driver.switch_to.default_content()

05 元素属性为动态属性,看着定位已经正确,但是随着鼠标点击位置不同,元素的属性发生变化。

解决方法:换元素的另一个固定属性来进行定位。

页面元素在页面打开的时候被其他弹出窗口挡住。

解决方法:添加关闭弹出窗口步骤。

 

总结:

感谢每一个认真阅读我文章的人!!!

作为一位过来人也是希望大家少走一些弯路,如果你不想再体验一次学习时找不到资料,没人解答问题,坚持几天便放弃的感受的话,在这里我给大家分享一些自动化测试的学习资源,希望能给你前进的路上带来帮助。

软件测试面试文档

我们学习必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有字节大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。

 

          视频文档获取方式:
这份文档和视频资料,对于想从事【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!以上均可以分享,点下方小卡片即可自行领取。

  • 27
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值