Selenium自动化测试第一天(上)
如有任何学习问题,可以添加作者微信:lockingfree
目录
Selenium是一款浏览器自动化框架,Webdriver是其核心,同过Webdriver将自动化脚本转化为浏览器操作指令。
一般操作逻辑为:
- 打开网页
- 定位页面元素(链接,按钮,输入框等)
- 操作页面元素(点击,输入)
- 定位并操作下一个页面元素
Webdriver的工作原理
Webdriver会在本地启动一套WebService服务并绑定一个动态端口,脚本运行时通过selenium将请求发送到Webdriver服务端,然后经过不同的浏览器驱动,转换为浏览器指令。
浏览器基本操作
- 方法
- get():打开网页
- forward():前进
- back(): 后退
- refresh(): 刷新页面
- maximize_window():最大化窗口
- set_window_size():设置窗口大小
- close(): 关闭当前页面
- quit(): 退出浏览器
- 属性
- title:标题
- current_url:当前网址
- page_source:网页源代码
示例:
from selenium import webdriver
from time import sleep
browser = webdriver.Chrome() # 打开Chrome
# browser = webdriver.Firefox() # 打开Firefox
# browser = webdriver.Edge() # 打开Edge
# browser = webdriver.Ie() # 打开Ie
browser.get("http://www.baidu.com") # 打开网页
browser.maximize_window() # 窗口最大化
print(browser.title) # 当前页面的标题
print(browser.current_url) # 当前url
print(browser.page_source) # 网页源代码
sleep(1)
browser.get("http://115.28.108.130/control.html")
sleep(1)
browser.back() # 后退
sleep(1)
browser.forward() # 前进
browser.refresh() # 刷新
sleep(3)
browser.quit() # 退出
页面元素定位
8种基本定位方式
- 通过id定位: find_element_by_id()
- 通过name定位: find_element_by_name()
- 通过class定位: find_element_by_class_name()
- 通过tag定位: find_element_by_tag_name()
- 通过link定位: find_element_by_link_text()
- 通过partial link定位: find_element_by_partial_link_text()
- 通过xpath定位: find_element_by_xpath()
- 通过css定位: find_element_by_css_selector()
示例:
from selenium import webdriver
from time import sleep
browser = webdriver.Chrome()
browser.maximize_window()
browser.get("http://115.28.108.130/control.html")
browser.find_element_by_id("accountID").send_keys("hello")
browser.find_element_by_name("password").send_keys("123456")
browser.find_element_by_class_name("stuname").send_keys("class")
div = browser.find_element_by_tag_name("div") # 重复较多,只能定位到第一个,不推荐使用
print(div.get_attribute("id"))
# browser.find_element_by_link_text("百度首页走起~").click()
link = browser.find_element_by_link_text("百度首页走起~")
print(link.text)
link.click()
sleep(1)
browser.back()
browser.find_element_by_partial_link_text("百度首页").click()
browser.back()
label2 = browserb.find_element_by_xpath('/html/body/div[4]/label[2]')
print(label2.text)
summer = browser.find_element_by_xpath('//input[@id="u"][@value="summer"]')
summer.click()
browser.find_element_by_css_selector('#input > input').send_keys("1111")
browser.find_element_by_css_selector("#accountID").send_keys("张三")
补充:用By定位元素:
- find_element(By.ID,"")
- find_element(By.NAME, "")
- find_element(By.CLASS_NAME, "")
- find_element(By.TAG_NAME, "")
- find_element(By.LINK_TEXT, "")
- find_element(By.PARTIAL_LINK_TEXT, "")
- find_element(By.XPATH, "")
- find_element(By.CSS_SELECTOR, "")
定位一组元素
当元素拥有相同的id/name/class_name/tag_name等时,可以定位到所有的元素,然后按顺序取得具体某个元素,这里使用find_elements_by_***,注意对一个s
from selenium import webdriver
from time import sleep
browser = webdriver.Chrome()
browser.maximize_window()
browser.get("http://115.28.108.130/control.html")
l = browser.find_elements_by_id("u")
for i in l:
i.click()
l[2].click()
lables = browser.find_elements_by_tag_name("label")
print(lables[2].text)
分层定位
当一个元素不好定位时,可以先定位到容易定位的父级/祖先级元素,然后使用父级/祖先级元素继续定位,如:
from selenium import webdriver
from time import sleep
browser = webdriver.Chrome()
browser.maximize_window()
browser.get("http://115.28.108.130/control.html")
fardiv = browser.find_element_by_class_name("fathdiv") # 先定位到父级元素
labels = fardiv.find_elements_by_tag_name("label") # 使用父级元素向下定位
print(labels[2].text)
页面元素操作
- link 链接
- click()
- input 输入框
- send_keys(): 输入
- clear(): 清空输入框
- get_attribute("value"): 获取输入框的值
- button 按钮
- click():
- isEnabled(): 是否可用
- submit():type=submit的按钮可以使用submit()同click()用于提交表单
- radio/checkbox 单选/复选框
- click(): 定位到选框可直接点击
- is_displayed(): 是否展示
- is_selected(): 是否选中状态
- select 下拉框(需要用Select)
- select_by_index(): 按索引选择选项
- select_by_value(): 按value值选择选项
- select_by_visiable_text(): 按选项名选择选项
示例:
from selenium import webdriver
from time import sleep
browser = webdriver.Chrome()
browser.maximize_window()
browser.get("http://115.28.108.130/control.html")
area = Select(browser.find_element_by_id("areaID"))
area.select_by_visible_text("上海")
sleep(1)
area.select_by_index(1)
sleep(1)
area.select_by_value("1")
Selenium自动化测试第一天(上)的更多相关文章
- Selenium自动化测试第二天(上)
如有任何学习问题,可以添加作者微信:lockingfree 目录 Selenium自动化测试基础 Selenium自动化测试第一天(上) Selenium自动化测试第一天(下) Selenium自动化 ...
- Selenium自动化测试第一天(下)
如有任何学习问题,可以添加作者微信:lockingfree 目录 Selenium自动化测试基础 Selenium自动化测试第一天(上) Selenium自动化测试第一天(下) Selenium自动化 ...
- Selenium自动化测试第二天(下)
如有任何学习问题,可以添加作者微信:lockingfree 目录 Selenium自动化测试基础 Selenium自动化测试第一天(上) Selenium自动化测试第一天(下) Selenium自动化 ...
- 《手把手教你》系列基础篇之(一)-java+ selenium自动化测试-环境搭建(上)(详细教程)
1.简介 jmeter系列的文章结束,本来想趁热打铁顺别将Jmeter和接口测试介绍一下,但是感觉Jmeter时间太长了怕大家吃腻了,还有一个原因就是许多小伙伴们或者童鞋们私信问宏哥什么时候可以有ja ...
- 《手把手教你》系列技巧篇(五十三)-java+ selenium自动化测试-上传文件-上篇(详细教程)
1.简介 在实际工作中,我们进行web自动化的时候,文件上传是很常见的操作,例如上传用户头像,上传身份证信息等.所以宏哥打算按上传文件的分类对其进行一下讲解和分享. 2.为什么selenium没有提供 ...
- 《手把手教你》系列技巧篇(五十四)-java+ selenium自动化测试-上传文件-中篇(详细教程)
1.简介 在实际工作中,我们进行web自动化的时候,文件上传是很常见的操作,例如上传用户头像,上传身份证信息等.所以宏哥打算按上传文件的分类对其进行一下讲解和分享. 2.为什么selenium没有提供 ...
- 《手把手教你》系列技巧篇(五十五)-java+ selenium自动化测试-上传文件-下篇(详细教程)
1.简介 在实际工作中,我们进行web自动化的时候,文件上传是很常见的操作,例如上传用户头像,上传身份证信息等.所以宏哥打算按上传文件的分类对其进行一下讲解和分享. 2.为什么selenium没有提供 ...
- Python网络数据采集7-单元测试与Selenium自动化测试
Python网络数据采集7-单元测试与Selenium自动化测试 单元测试 Python中使用内置库unittest可完成单元测试.只要继承unittest.TestCase类,就可以实现下面的功能. ...
- Selenium自动化测试框架入门整理
关注嘉为科技,获取运维新知 本文主要针对Selenium自动化测试框架入门整理,只涉及总体功能及框架要点介绍说明,以及使用前提技术基础要求整理说明.作为开发人员.测试人员入门参考. 本文参考:Se ...
随机推荐
- maven 打包时动态替换properties资源文件中的配置值
pom build节点下面添加resource配置: <resources> <resource> <directory>src/main/resources/&l ...
- centos7修改主机名和ip映射
1.修改主机名:命令:/etc/hostname文件输入:HOSTNAME=node3想永久修改,应该修改配置文件 /etc/sysconfig/network. 输入:NETWORKING=yes ...
- POJ 1753 Flip Game (状态压缩 bfs+位运算)
Flip game is played on a rectangular 4x4 field with two-sided pieces placed on each of its 16 square ...
- jQuery获取所有父级元素及同级元素及子元素的方法
jQuery获取所有父级元素及同级元素及子元素的方法 1.获取父级元素 $("#id").parent() 获取其父级元素 $("#id").parents() ...
- 【Linux资源管理】使用sar进行性能分析
sar可用于监控Linux系统性能,帮助我们分析性能瓶颈.sar工具的使用方式为”sar [选项] intervar [count]”,其中interval为统计信息采样时间,count为采样次数. ...
- mysql对查出来的值,在sql里面拼接我们想要拼接的内容
MySQL中concat函数使用方法:CONCAT(str1,str2,…) 返回结果为连接参数产生的字符串.如有任何一个参数为NULL ,则返回值为 NULL. 注意:如果所有参数均为非二进制字符串 ...
- SQL Server公用表达式CET递归查询所有上级数据
with cte as( select bianma,fjbm from #tree where chkDisabled='true' union all select t.bianma,t.fjbm ...
- 正则表达式-Regular expression学习笔记
正则表达式 正则表达式(Regular expression)是一种符号表示法,被用来识别文本模式. 最近在学习正则表达式,今天整理一下其中的一些知识点 grep - 打印匹配行 grep 是个很强大 ...
- java端连接zookeeper出现unknowHostException错误
连接zookeeper出现异常:unknowHostException 出现这种错误一开始以为是zookeeper的配置文件出了问题,所以一直在找配置文件的问题,但是zookeeper在虚拟机里面是可 ...
- socketpair通信
1.线程间通信(参考安卓源码InputTransport.cpp) #include <pthread.h> #include <sys/types.h> /* See NOT ...