一、等待的作用
1、在系统的功能运行过程中,所有的内容是需要一定的时间来实现展示,
2、时间耗费长短与网络速度、系统框架设定、接口的执行复杂度有关,
3、因此需要设置缓冲时间,若未设置缓冲时间,容易导致元素找不到
二、等待方式
强制等待 sleep()
导入time中的sleep,等待X秒后再执行后面的代码
缺点
1、无法精确把握等待的时间(如无法判断页面是否加载完成,是否可以进行下一步操作)
2、一直使用强制等待会降低自动化效率,浪费大量时间
优点
1、简单使用,一般在调试中使用
隐式等待
设置一个隐形的等待,设置最长等待时间,如果在这个时间内完成了页面内容全部加载,则进行下一步操作,否则一直等待时间结束,再进行下一步
缺点
必须等待页面加载完成才能进行下一步,应用度上不太灵活
优点
对整个WebDriver周期有效,所以只需要设置一次
显示等待
专门用于指定的条件进行等待,在设置的最大时长内,依照查找的时间频率来进行搜索,查找指定的对象,until表示如果找到,则继续下一步,否则报出异常
优点
精确对某个特定条件进行等待,条件成立进行下一步,否则报出异常
缺点
应用上而言,相较于其他两种等待更为复杂
三、自动化中应该避免的坑
页面元素定位不到原因:
1、元素定位错误
2、未添加等待时间
3、直接copy容易出错
针对上述问题,采用xpath方式手写定位,确认元素的正确性
四、代码实现
1 from selenium import webdriver
2 from selenium.webdriver.support.wait import WebDriverWait
3 from selenium.webdriver.support import expected_conditions as ec
4 from selenium.webdriver.common.by import By
5 dr=webdriver.Chrome()
6
7 #隐式等待
8 dr.implicitly_wait(20)
9
10 dr.get('http://www.baidu.com')
11
12 #显示等待
13 element = WebDriverWait(dr,20).until(ec.presence_of_element_located((By.ID,'KW')))
14 element.send_keys('selenium')
15
16 dr.quit()
五、expected_conditions类说明
1 ec.title_is 判断当前页面标题是否符合预期
2 ec.title_contains 判断当前页面标题是否包含预期字符串
3 ec.presence_of_element_located 判断元素是否被加载DOM树里,不代表元素一定可见
4 ec.visibility_of_element_located 判断元素是否可见
5 ec.visibility_of 与上面方法作用相同,只是上面方法参数为定位,该方法接收的参数为定位后的元素
6 ec.presence_of_all_elements_located 判断是否至少有一个元素存在DOM树里
7 ec.text_to_be_present_in_element 判断某个元素的text是否包含预期的字符串
8 ec.text_to_be_present_in_element_value 判断某个元素的value属性是否包含预期的字符串
9 ec.frame_to_be_available_and_switch_to_it 判断该表单是否可以切换进去
10 ec.invisibility_of_element_located 判断某个元素是否不存在DOM树里
11 ec.element_to_be_clickable 判断某个元素是否可见并可以点击
12 ec.staleness_of 等到一个元素从DOM树里移除
13 ec.element_to_be_selected 判断某个元素是否被选中
14 ec.element_selection_state_to_be 与上面方法作用相同,只是上面方法参数为定位,该方法接收的参数为定位后的元素
15 ec.alert_is_present 判断页面是否存在alert