Selenium一本通

Selenium中文官方文档

从一个测试脚本说起

python 复制代码
from selenium import webdriver #引入selenium webdriver模块
driver = webdriver.Firefox() #初始化Firefox浏览器的webdriver对象,启动浏览器
driver.get("http://cn.bing.com/") #跳转到对应页面
assert 'Bing' in driver.title #检查页面标题是否包含某一信息
driver.quit() #关闭浏览器

Selenium家族

  • Selenium IDE:浏览器组件,提供录制回放功能,可以将录制生成多种编程语言脚本,快速创建测试用例;
  • Selenium Grid:支持分布式测试,在不同平台、浏览器的多态远程机器上同时运行Selenium测试脚本,提交效率;
  • Selenium RC(Remote Control):Java语言编写服务端,处理测试脚本发来的HTTP请求,操作浏览器(Selenium2后与WebDriver合并,使用驻留Chrome、IE、FireFox浏览器);
  • Selenium WebDriver:调用WebDriver对象操作浏览器。

Selense命令集合

  • Action: open\type\click\sendKeys
  • Accessor:将值保存至变量
  • Assertions:检查点。
    1)Assert断言,检查指定条件是否满足,不满足,终止test case运行;
    2)verify验证指定条件是否等于期望值,若不满足,则仅当前步骤失败,继续执行下一步。
  • Wait:等待元素加载完成后操作。
    1)***AndWait执行操作后等待页面刷新完成才进行下一步,如clickAndWait点击并等待;
    2)waitFor*** 等待直到复合某一特定条件才进行下一步,如waitForElementPresent 等待知道指定元素出现在页面上。隐式等待,如果条件满足,就立即执行下一步,否则等到selenium IDE设置的最大等待时间,因此具体等待时间不确定。
  1. pause 显示等待,明确了等待时间,一定等到时间结束为止。
    selenium IDE默认最大等待时间30000ms(30s),超时未找到元素则测试步骤失败,脚本抛出异常。

常见的元素定位方法

F12工具栏第一各图标-在页面中选择一个元素以进行检查,可以以通过悬停在元素上方定位html语言。

选中html语言,点击右键,可以复制selector/xpath等

  1. 通过元素id定位
python 复制代码
WebElement ele = driver.find_element('id', value)
WebElement ele = driver.find_element(By.ID, value)
  1. 元素Name:'name' By.NAME
  2. xpath表达式:'xpath' By.XPATH
  3. 完整超链接:'link text' By.LINK_TEXT
  4. 部分链接:'partial text' By.PARTIAL_LINK
  5. 标签:'tag name' By.TAG_NAME
  6. 类名:'class name' By.CLASS_NAME
  7. css选择器:'css selector' By.CSS_SELECTOR

如何选择定位方法?

首选id,具有唯一性,缺少id属性或id动态刷新时选择其它;

TagName/ClassName:先找到一类元素,再通过具体的顺序位置定位到某一个元素;

LinkTest/PartialLinkTest:定位链接时;

XPath/cssSelector:定位很强大,但定位性能不是很好,可读性也会变差,少数元素不好定位时选择。

实例

一、环境搭建

1. 安装selenium库
shell 复制代码
pip install selenium
2. 安装浏览器驱动

网页链接:Microsoft Edge Driver - Microsoft Edge Developer

简单起见将下载的msedgedriver.exe与py文件放在同一目录下,可以不用配置环境变量。

二、初始化

1. 启动浏览器驱动
python 复制代码
from selenium import webdriver
wd = webdriver.Edge() #"msedgedriver"
2. 设置等待时间
python 复制代码
wd.implicitly_wait(5)
3. 打开网站
python 复制代码
wd.get("https://www.bv2008.cn/app/user/register.php?type=org")
4. 程序的最后关闭浏览器驱动
python 复制代码
wd.quit()

三、选择元素

1. 导入库
python 复制代码
from selenium.webdriver.common.by import By
2. 根据ID查找
python 复制代码
element = wd.find_element(By.ID, 'ID值')
3. 根据css选择器查找
python 复制代码
element = wd.find_element(By.CSS_SELECTOR, 'css选择器')
4. 其他查找方法
python 复制代码
element = wd.find_element(By.CLASS_NAME, 'class属性')
element = wd.find_element(By.TAG_NAME, '标签名')
5. find_element与find_elements
python 复制代码
find_element返回一个元素(第一个)
find_elements返回元素列表

四、操作元素

1. 输入文字:send_keys()
python 复制代码
element.send_keys('文本')			# 用于文本框
2. 点击:click()
python 复制代码
element.click()			# 用于按钮、超链接、单选框、多选框、
3. 下拉框选择
python 复制代码
s = Select(element)
s.select_by_value('value值')
# s.select_by_visible_text('文本信息')

五、切换窗口

1. iframe
python 复制代码
# 进入到iframe
wd.switch_to.frame('iframe名')
# wd.switch_to.frame(element)

# 回到原页面
wd.switch_to.default_content()
2. 切换页面
python 复制代码
for window_handle in wd.window_handles:
    wd.switch_to.window(window_handle)
    if '内容' in wd.title:
        break
相关推荐
~-~%%1 分钟前
从PyTorch到ONNX:模型部署性能提升
人工智能·pytorch·python
蒋星熠6 分钟前
Flutter跨平台工程实践与原理透视:从渲染引擎到高质产物
开发语言·python·算法·flutter·设计模式·性能优化·硬件工程
爬虫程序猿1 小时前
《京东商品详情爬取实战指南》
爬虫·python
胡耀超1 小时前
4、Python面向对象编程与模块化设计
开发语言·python·ai·大模型·conda·anaconda
大佬,救命!!!2 小时前
整理python快速构建数据可视化前端的Dash库
python·信息可视化·学习笔记·dash·记录成长
孔丘闻言2 小时前
python调用mysql
android·python·mysql
Teletele-Lin2 小时前
Miniconda安装与VSCode搭建远程Python、Jupyter开发环境
vscode·python·jupyter·环境配置·远程开发
伊玛目的门徒3 小时前
告别 OpenAI SDK:如何使用 Python requests 库调用大模型 API(例如百度的ernie-4.5-turbo)
python·openai·requests·大模型调用·ernie-4.5-turbo
sinat_602035364 小时前
模块与包的导入
运维·服务器·开发语言·python
计算机学姐4 小时前
基于Python的旅游数据分析可视化系统【2026最新】
vue.js·后端·python·数据分析·django·flask·旅游