• Selenium2+Python自动化-处理浏览器弹窗(转载)


    本篇转自博客:上海-小T

    原文地址:http://blog.csdn.net/real_tino/article/details/59068827

    我们在浏览网页时经常会碰到各种花样的弹窗,在做UI自动化测试的时候势必要处理这些弹窗,这里就介绍一下目前前端界两种弹窗的处理方法。

    一、alert弹窗 
    alert弹窗 
    这种弹窗是最简单的一种,Selenium里有自带的方法来处理它,用switch_to.alert先定位到弹窗,然后使用一系列方法来操作:

    • accept - 点击【确认】按钮
    • dismiss - 点击【取消】按钮(如有按钮)
    • send_keys - 输入内容(如有输入框)

    这里举一个菜鸟教程上的一个例子:http://www.runoob.com/try/try.php?filename=tryjs_alert,在页面左边点击【显示警告框】就会弹出一个alert弹窗: 
    例子

    我们用以下代码就能实现切换至弹窗并点击【确定】按钮的效果:

    al = driver.switch_to_alert()
    al.accept()

    这里这个switch_to_alert()其实是旧写法,照理应该是用switch_to.alert(),但是新写法却会报错,目前猜测是版本问题,可能不支持新写法,这里就先用旧写法。

    以下是完整代码,为了运行的时候看得清楚,我加了两处等待:

    # encoding:utf-8
    
    from selenium import webdriver
    import time
    
    driver = webdriver.Firefox()
    driver.get("http://www.runoob.com/try/try.php?filename=tryjs_alert")
    driver.switch_to.frame("iframeResult")
    driver.find_element_by_xpath("html/body/input").click()
    time.sleep(1)
    al = driver.switch_to_alert()
    time.sleep(1)
    al.accept()
    

    二、自定义弹窗 
    由于alert弹窗不美观,现在大多数网站都会使用自定义弹窗,使用Selenium自带的方法就驾驭不了了,此时就要搬出JS大法。这里举一个新世界教育官网首页的例子: 
    新世界教育官网首页 
    大家能看到,图中的这种弹窗就是现在主流的表现形式,处理这种弹窗可以利用HTML DOM Style 对象,有一个display属性,可以设置元素如何被显示,

    详细解释可以参考http://www.w3school.com.cn/jsref/prop_style_display.asp。将display的值设置成none就可以去除这个弹窗了:

    js = 'document.getElementById("doyoo_monitor").style.display="none";'

    完整代码如下:

    # encoding:utf-8
    
    from selenium import webdriver
    import time
    
    driver = webdriver.Firefox()
    driver.get("http://sh.xsjedu.org/")
    time.sleep(1)
    js = 'document.getElementById("doyoo_monitor").style.display="none";'
    driver.execute_script(js)
    

    是不是既简单又高效~

  • 相关阅读:
    什么样的基础设施适合快速和大数据架构?
    四大关键步骤掌握CloudOps模型
    容器技术适合你的企业吗
    内存压缩PK页面交换 解决内存问题谁更在行
    内存共享和过量使用区别在哪里
    网络策略中使用的 VLAN 属性
    四大VDI客户端 总有一款适合你
    使用Windows SFC和DISM工具来解决服务器OS问题
    远程 RADIUS 服务器组
    excel知识
  • 原文地址:https://www.cnblogs.com/caoj/p/7813690.html
Copyright © 2020-2023  润新知