一.切换窗口和标签页

1.webdriver 不区分窗口和标签页

2.打开一个新的标签页或窗口,selenium会使用窗口句柄来处理它

3.每个窗口都有一个唯一的标识符,该标识符在单个会话中保持持久性
4.获取当前窗口句柄

driver.current_window_handle
5.获取所有窗口句柄

driver.window_handles 返回的是一个列表
6.切换窗口句柄

driver.switch_to.window(window_handle) 
#window_handle表示的是要切换到哪个窗口句柄
7.窗口句柄:由操作系统 生成的一串唯 一识别码,是一串字符
import time
​
from selenium import webdriver
​
with webdriver.Chrome() as driver:
    driver.get('http://www.baidu.com')
    # 找到输入框输入图片
    driver.find_element_by_link_text('新闻').click()print(driver.current_window_handle)  # 获取当前窗口
    l = driver.window_handles  # 返回所有窗口
    print(l)
    driver.switch_to.window(l[-1])  # 切换窗口
    print(driver.current_window_handle)
    time.sleep(5)

二.元素等待

1.浏览器渲染页面的时候需要时间,如果没有渲染完成就对元素进行定位将会找不到该元素,所有添加延时进行等待
2.显示等待
2.1.定位指定元素时,如果能找到该元素,那么就直接返回该元素
2.1.1.如果找不到,那么每隔指定的时间再去定位该元素
2.1.2.如果超出最长等待时间,那么就抛出TimeOutException
2.2.显示等待的实现
from selenium import webdriver
from selenium.webdriver.support.wait import WebDriverWait
from selenium.webdriver.support import expected_conditions as EC
​
WebDriverWait(driver,timeout=3).until(EC.visibility_of_element_located(('id','3001'))).click()
2.3.WebDriverWait等待类需要导入
2.3.1.driver指的是浏览器驱动对象

2.3.2.timeout表示的是最长等待时间

2.3.3.poll_frequency表示的是检测的间隔时间,默认是0.5
2.4.后面跟上until方法,在until方法跟上匿名函数来实现元素定位
2.5.until方法接受1个参数
-conditions

条件在selenium.webdriver.support.expected_conditions模块中

常见条件:
    presence_of_element_located         元素存在于dom中
    visibility_of_element_located           元素可见
    element_to_be_clickable                 元素可点击
    element_to_be_selected                 元素可选择
import time
from selenium import webdriver
from selenium.webdriver.support.wait import WebDriverWait
from selenium.webdriver.support import expected_conditions as EC
from selenium.webdriver.common.by import By
​
with webdriver.Chrome() as driver:
    driver.get('http://www.baidu.com')
    # 找到输入框输入图片
    driver.find_element_by_id('kw').send_keys('图片')
    driver.find_element_by_id('su').click()
    time.sleep(3)# 选取第一个结果并点击
    # 会等待xpath为//div[@srcid="4"]/div//a的元素可见,timeout=3表示最多等待3秒钟,超时就抛出异常
    # 可具体细分为以下代码
    # 创建一个等待对象,webdriver 最长等待时间,轮询频率
    # wait=WebDriverWait(driver, timeout=3)
    # 条件,等待结束的条件 locator (by,exp)
    # ec=EC.visibility_of_element_located('xpath', '//div[@srcid="4"]/div//a')
    # element=wait.until(ec)
    # element.click# WebDriverWait(driver, timeout=3).until((EC.visibility_of_element_located('xpath',//div[@srcid="4"]/div//a'))).click()
    WebDriverWait(driver,timeout=10).until(EC.visibility_of_element_located((By.XPATH,'//div[@srcid="4"]/div//a'))).click()
​
    time.sleep(5)
    print(driver.current_window_handle)  # 获取当前窗口
    l = driver.window_handles  # 返回所有窗口
    print(l)
    driver.switch_to.window(l[-1])  # 切换窗口print(driver.current_window_handle)
    time.sleep(5)
2.6.显示等待超时可能原因
2.6.1.表达式有问题

2.6.2.条件使用错误

2.6.3.需要和time.sleep结合使用

2.6.4.元素定位错误
3.隐式等待
3.1.隐式等待本质上是设置了一个全局等待时间,轮询查看页面是否加载完成

3.1.1.如果超过最长等待时间页面未加载完成则抛出异常,默认情况下隐式等待是禁用的
3.2.警告:不要混用隐式等待和显示等待,这样会导致不可预测的等待时间
3.3.例如:隐式等待设置10秒,显示等待设置15秒,可能导致在20秒后发生超时
from selenium import webdriver
​
with webdriver.Chrome() as driver:
    # 设置隐式等待5秒
    driver.implicitly_wait(5)
    driver.get('http://www.baidu.com')
​
    driver.find_element_by_id('kw').send_keys('图片')
    driver.find_element_by_id('su').click()
    
    driver.find_element_by_xpath('//div[@srcid="4"]/div//a').click()print(driver.current_window_handle)  # 获取当前窗口
    l = driver.window_handles  # 返回所有窗口
    print(l)
    driver.switch_to.window(l[-1])  # 切换窗口print(driver.current_window_handle)
4.强制等待
4.1.强制等待就是让代码休眠,不做任何的操作
4.2.使用:ime.sleep(time) 单位为time
from selenium import webdriver
​
with webdriver.Chrome() as driver: 
    driver.get('http://www.baidu.com')
    # 强制等待5秒
    time.sleep(5)

三.常用场景

1.当要获取元素的文本内容时,而元素的文本内容是需要通过后台接口请求并渲染的
1.1.此时,如果使用隐式等待或显示等待是没有办法获取到文本内容,所以需要使用强制等待

2.当要操作的元素已经存在,但是有其他的元素需要等待且与该操作的元素有业务关联
2.1.如果使用隐式等待或显示等待对该元素进行操作的话,是没有办法进行的,也需要使用强制等待

四.显示等待与隐式等待的区别

1.抛出的异常不一样,隐式等待超时,报的NoSuchElementException ,显示等待超时,报的是TimeOutException

2.作用域不一样, 隐式等待对所有元素定位的方法都有效,只需要定义一次, 显示等待只针对单个元素

3.显示等待不需要等待整个页面的HTML的DOM树加载完成,显式等待的效率更高,工作当中一般使用显示等待
3.1.而隐式等待需整个HTML DOM树加载完成
Logo

AtomGit 是由开放原子开源基金会联合 CSDN 等生态伙伴共同推出的新一代开源与人工智能协作平台。平台坚持“开放、中立、公益”的理念,把代码托管、模型共享、数据集托管、智能体开发体验和算力服务整合在一起,为开发者提供从开发、训练到部署的一站式体验。

更多推荐