• python 中的三种等待方式


    为什么要用等待时间:

    1. 今天在写App的自动化的脚本时发现一个元素,但是往往执行脚本是报错( An element could not be located on the page using the given search parameters.),提示没有找到元素这时就可能出现时而能点击,时而又不能点击到,原因是:因为元素还没有被加载出来,查找的代码就已经被执行了,自然就找不到元素了.解决方式:可以用等待,等元素加载完成后再执行查找元素语句。

    Python里有三种等待的方式:

    1、强制等待

    导入定时等待库 

    from time import sleep 或者 import time

    time.sleep(10)            # 表示强行等待10s在执行下一句代码 这种等待方式时间到了就会执行下个语句,但比较死板,不能保证在等待的时间内元素真正被加载了出来。而且如果等待的元素已经被加载出来,还需要等待到时间才会执行下一句,浪费时间。

    2、 隐性等待

    1. driver.implicitly_wait(30)   #等待30s
    2. 这个等待表示在规定的时间内页面的所有元素都加载完了就执行下一步,否则一直等到时间截止,然后再继续下一步。
    3. 这个方法的缺点是你需要的元素已经加载出来了,但页面还没有加载完,再需要继续等待页面加载完才能执行下一步操作。

    3、显性等待

    需要导入的包

    from selenium.webdriver.support.wait import WebDriverWait #导入显性等待的包

      from selenium.webdriver.support import expected_conditions as EC #判断所需要的元素是否已经被加载出来  

     from selenium.webdriver.common.by import By #定位

    1. WebDriverWait,配合该类的until()和until_not()方法,表示程序每隔x秒去判断一下指定的元素是否加载完,加载完了就执行下一步,否则继续每隔x秒去判断,指定时间截止。如果超时就会抛出异常。
    2. until()和until_not()方法

                        until()   判断,直到返回值为true,执行下一步

                        nutil_not    判断,直到返回值为false    执行下一步

    如下 

      

    1. WebDriverWait(driver, 30, 0.5).until(EC.presence_of_element_located((By.ID, 'com.hanshow.wisepick:id/activity_login_btn')))
          #在30s内,每隔0.5s检查一次所需要的元素是否被加载出来,加载出来了就执行下一步,没有加载出来就继续等待,
      driver.find_element_by_id("com.hanshow.wisepick:id/activity_login_btn").click()  #执行找到的元素
  • 相关阅读:
    难以理解的二分查找
    程序设计第七次作业——关于计算器的总结
    程序设计第六次作业——计算器(可视化界面)
    课堂作业——1025反转链表
    程序设计第五次作业——计算器(调用文件输入输出)
    circle area
    程序设计第四次作业——计算器第二步(计算)
    第三次作业代码规范修改
    解决Type 'UnityEngine.Component' does not support slicing
    mactype支持qq浏览器
  • 原文地址:https://www.cnblogs.com/Abell/p/12988948.html
Copyright © 2020-2023  润新知