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
相关推荐
码上淘金19 分钟前
【Python】Python常用控制结构详解:条件判断、遍历与循环控制
开发语言·python
Brilliant Nemo22 分钟前
四、SpringMVC实战:构建高效表述层框架
开发语言·python
2301_787552871 小时前
console-chat-gpt开源程序是用于 AI Chat API 的 Python CLI
人工智能·python·gpt·开源·自动化
懵逼的小黑子1 小时前
Django 项目的 models 目录中,__init__.py 文件的作用
后端·python·django
Y3174291 小时前
Python Day23 学习
python·学习
Ai尚研修-贾莲2 小时前
Python语言在地球科学交叉领域中的应用——从数据可视化到常见数据分析方法的使用【实例操作】
python·信息可视化·数据分析·地球科学
qq_508576093 小时前
if __name__ == ‘__main__‘
python
学地理的小胖砸3 小时前
【Python 基础语法】
开发语言·python
程序员小远3 小时前
自动化测试与功能测试详解
自动化测试·软件测试·python·功能测试·测试工具·职场和发展·测试用例
_Itachi__3 小时前
Model.eval() 与 torch.no_grad() PyTorch 中的区别与应用
人工智能·pytorch·python