• selenium等待元素出现


    在自动化脚本中我们打开指定网址后,为了防止页面报错我们一般强制让页面sleep1s。但是这样固定的等待时间会导致我们测试用例执行加长,本篇主要就等待web元素的出现的两种用法进行展开,包括隐式等待和显示等待。

    隐式等待(driver.implicitly_wait()

    1)概述:全局的设定,后面所有的选择元素的代码都不需要单独的指定周期性的等待

    2)格式:driver.implicitly_wait(5)

    3)解释:执行了driver.implicitly_wait(5) 这段代码之后,后面任何选择元素操作,最多可以等待5s。若元素未找到会每隔0.5s执行一次直到超出最大等待时间

    4)注意:隐式等待只能保证找到元素,但是并不能找到所有元素。此时可以选择强制sleep让页面完全刷新出来

    from selenium import webdriver
    driver=webdriver.Chrome()
    #隐式等待:设置最大等待时间5s,作用于整个webdriver
    driver.implicitly_wait(5)

    显示等待

    1)引入:如果有一个特殊的操作需要等待30s,其余操作5s内均可做出响应。应该如何做呢?

    2)概述:为一个操作专门指定等待时间(针对具体的操作)

    方法1:
    from selenium.webdriver.support.ui import WebDriverWait
    from selenium.webdriver.support import expected_conditions as EC
    from selenium.webdriver.common.by import By
    ele = WebDriverWait(driver, 60).until(EC.presence_of_element_located((By.ID,'1')))#60s
    不用强记,需要使用的时候直接拷贝,修改后面的元素值即可**((By.ID,'1'))**
    方法2::先用临时隐式等待改为60秒,等操作结束之后再改为5秒
    from selenium import webdriver
    driver=webdriver.Chrome()
    driver.implicitly_wait(5)
    driver.get('http://www.baidu.com')
    ele=driver.find_element_by_id('kw')
    ele.send_keys('python百度百科')
    button=driver.find_element_by_id('su')
    button.click()
    #**********耗时操作开始#**********
    driver.implicitly_wait(60)
    res=driver.find_element_by_id('1')
    connent = res.text
    if res.text.startswith('Python是一种计算机程序设计语言') :
        print('测试通过')
    else:
        print('测试失败')
    print(connent)
    #**********耗时操作结束#**********
    driver.implicitly_wait(5)

     

    参考链接:https://www.jianshu.com/p/1ec2f6052397

  • 相关阅读:
    Windows Server2016环境中安装Oracle12c数据库
    centos7 安装Oracle19C 数据库
    centos7 磁盘分区以及磁盘挂载
    PHP日常开发技巧散记
    代码压缩工具 webpack安装与入门使用【初级】
    程序员修炼之道系列 | 使用曳光弹找到目标
    程序员修炼之道系列 | 不要冲出前灯范围
    程序员修炼之道系列 | 敏捷估算
    程序员修炼之道系列 | “豆腐渣“工程竟然也能做原型
    官宣!禅道与极狐(GitLab)达成深度合作,携手推进开源开放DevOps生态
  • 原文地址:https://www.cnblogs.com/hkgov/p/13893061.html
Copyright © 2020-2023  润新知