Selenium核心技巧:元素定位与等待策略

Selenium核心技巧

  1. WebDriver:浏览器(交互)
  2. find_element:元素定位
  3. WebElement元素(交互)

重点内容:

  1. 元素定位
  2. 等待
  3. 元素交互
    1. 文件上传(3种)
    2. 滚动条处理
    3. JS代码(强制操作)

1、元素定位

  • 方法

    • find_element:如果成功返回元素,如果失败抛出异常。
    • find_elements:如果成功返回list,如果失败返回list(空)
  • 策略
    *

    复制代码
    基于元素的属性进行定位
    ID = "id"
    NAME = "name" 
    TAG_NAME = "tag name" 
    CLASS_NAME = "class name"
    
    基于链接文件进行定位
    LINK_TEXT = "link text"
    PARTIAL_LINK_TEXT = "partial link text"
    
    可以定位任意元素
    XPATH = "xpath"
    CSS_SELECTOR = "css selector"

2、等待

  • 隐式等待
    *

    复制代码
    driver = webdriver.Edge(options=options, service=service)
    driver.implicitly_wait(20)     #隐式等待(放在浏览器启动之后,等待浏览器加载完成)
  • 显示等待
    *

    复制代码
    #显示等待(一般放在需要等待的上一个执行代码段)
    # WebDriverWait(driver,timeout=10).until(lambda x: driver.find_element(By.XPATH, value='//*[@id="s-top-left"]/a[1]'))
    
    wait=WebDriverWait(driver, 10)
    wait.until(lambda d: 1==1)   #等待条件
    
    #el=driver.find_element(by='xpath', value='//*[@id="s-top-left"]/a[1]')
    el=driver.find_element(By.XPATH, value='//*[@id="s-top-left"]/a[1]')
  • 流畅等待(更高级的等待)

  • 强制等待(休眠)
    *

    复制代码
    #强制等待
    import time
    time.sleep(3)
相关推荐
卓码软件测评9 小时前
第三方CNAS软件测评机构:【Gatling性能测试工具中的正则表达式提取的saveAs、transform和match组合使用】
测试工具·性能优化·测试用例
Pyeako12 小时前
网络爬虫相关操作--selenium库(超详细版)
爬虫·python·selenium
袁袁袁袁满13 小时前
基于selenium和亮数据爬取海外电商平台
爬虫·selenium·网络爬虫·数据采集·爬虫实战·电商采集·自动化采集
测试老哥14 小时前
UI自动化测试—Jenkins配置优化
自动化测试·软件测试·python·测试工具·ui·jenkins·测试用例
子夜江寒15 小时前
基于Selenium的自动化Web数据采集实践
selenium·自动化
卓码软件测评15 小时前
第三方CMA/CNAS软件测评机构:【Apifox在Dubbo接口调试和RPC服务测试中的测试应用】
网络·测试工具·性能优化·测试用例
测试老哥15 小时前
2026软件测试面试大全(含答案+文档)
自动化测试·软件测试·python·测试工具·面试·职场和发展·测试用例
程序员杰哥15 小时前
接口测试之文件上传
自动化测试·软件测试·python·测试工具·职场和发展·测试用例·接口测试
oioihoii16 小时前
VS Code 1.107 更新:多智能体协同与开发体验升级
测试工具
软件测试大叔17 小时前
Playwright、Puppeteer、Selenium 自动化测试框架对比分析
测试工具