如有任何学习问题,可以添加作者微信:lockingfree

目录

Selenium是一款浏览器自动化框架,Webdriver是其核心,同过Webdriver将自动化脚本转化为浏览器操作指令。

一般操作逻辑为:

  1. 打开网页
  2. 定位页面元素(链接,按钮,输入框等)
  3. 操作页面元素(点击,输入)
  4. 定位并操作下一个页面元素

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自动化测试第一天(上)的更多相关文章

  1. Selenium自动化测试第二天(上)

    如有任何学习问题,可以添加作者微信:lockingfree 目录 Selenium自动化测试基础 Selenium自动化测试第一天(上) Selenium自动化测试第一天(下) Selenium自动化 ...

  2. Selenium自动化测试第一天(下)

    如有任何学习问题,可以添加作者微信:lockingfree 目录 Selenium自动化测试基础 Selenium自动化测试第一天(上) Selenium自动化测试第一天(下) Selenium自动化 ...

  3. Selenium自动化测试第二天(下)

    如有任何学习问题,可以添加作者微信:lockingfree 目录 Selenium自动化测试基础 Selenium自动化测试第一天(上) Selenium自动化测试第一天(下) Selenium自动化 ...

  4. 《手把手教你》系列基础篇之(一)-java+ selenium自动化测试-环境搭建(上)(详细教程)

    1.简介 jmeter系列的文章结束,本来想趁热打铁顺别将Jmeter和接口测试介绍一下,但是感觉Jmeter时间太长了怕大家吃腻了,还有一个原因就是许多小伙伴们或者童鞋们私信问宏哥什么时候可以有ja ...

  5. 《手把手教你》系列技巧篇(五十三)-java+ selenium自动化测试-上传文件-上篇(详细教程)

    1.简介 在实际工作中,我们进行web自动化的时候,文件上传是很常见的操作,例如上传用户头像,上传身份证信息等.所以宏哥打算按上传文件的分类对其进行一下讲解和分享. 2.为什么selenium没有提供 ...

  6. 《手把手教你》系列技巧篇(五十四)-java+ selenium自动化测试-上传文件-中篇(详细教程)

    1.简介 在实际工作中,我们进行web自动化的时候,文件上传是很常见的操作,例如上传用户头像,上传身份证信息等.所以宏哥打算按上传文件的分类对其进行一下讲解和分享. 2.为什么selenium没有提供 ...

  7. 《手把手教你》系列技巧篇(五十五)-java+ selenium自动化测试-上传文件-下篇(详细教程)

    1.简介 在实际工作中,我们进行web自动化的时候,文件上传是很常见的操作,例如上传用户头像,上传身份证信息等.所以宏哥打算按上传文件的分类对其进行一下讲解和分享. 2.为什么selenium没有提供 ...

  8. Python网络数据采集7-单元测试与Selenium自动化测试

    Python网络数据采集7-单元测试与Selenium自动化测试 单元测试 Python中使用内置库unittest可完成单元测试.只要继承unittest.TestCase类,就可以实现下面的功能. ...

  9. Selenium自动化测试框架入门整理

    ​​关注嘉为科技,获取运维新知 本文主要针对Selenium自动化测试框架入门整理,只涉及总体功能及框架要点介绍说明,以及使用前提技术基础要求整理说明.作为开发人员.测试人员入门参考. 本文参考:Se ...

随机推荐

  1. PAT——1001. 害死人不偿命的(3n+1)猜想

    卡拉兹(Callatz)猜想: 对任何一个自然数n,如果它是偶数,那么把它砍掉一半:如果它是奇数,那么把(3n+1)砍掉一半.这样一直反复砍下去,最后一定在某一步得到n=1.卡拉兹在1950年的世界数 ...

  2. MVC验证码生成类库

    public class ValidateCode { /// <summary> /// 验证码的最大长度 /// </summary> public int MaxLeng ...

  3. Oracle创建表、修改表、删除表、约束条件语法

    一. 使用create关键字创建表 --(1)创建新表use 数据库(在那个数据库中建表)create table 表名(字段名1(列名) 数据类型 列的特征,字段名2(列名) 数据类型 列的特征(N ...

  4. C++ Primer学习笔记_1_快速入门

    C++快速入门 一 编写简单程序 // main是操作系统唯一显示调用的函数int main() {/**return返回的值是一个状态指示器 0:成功 非0:返回错误给OS*以echo $?命令可以 ...

  5. 持续集成(CI – Continuous Integration)

    持续集成(CI – Continuous Integration) 在传统的软件开发中,整合过程通常在每个人完成工作之后.在项目结束阶段进行.整合过程通常需要数周乃至数月的时间,可能会非常痛苦.持续集 ...

  6. Django学习笔记4-csrf防护

    1.CSRF验证失败. 请求被中断. 原因是django为了在用户提交表单时防止跨站攻击所做的保护 什么是 CSRF CSRF, Cross Site Request Forgery, 跨站点伪造请求 ...

  7. 原生JS实现移动端的轮播效果

    首先 我们想实现的效果是在手指按下拖动的时候图片能够跟随移动(无动画效果)然后松开手指后判断图片移动的位置 和某一个值进行比较 在这里我们默认定为盒子的1/3宽度 当x轴的移动位置大于1/3的时候图片 ...

  8. vuejs 解决跨域访问问题

    首先: config/index.js下面的proxyTable配置您的服务访问基本地址,将changeOrigin设置为true即可,然后在你需要访问接口的地方,这样使用,以下是我的工程代码(前提是 ...

  9. MySQL5.7主从同步--点位方式及GTID方式

    MySQL5.6加入了GTID的新特性,其全称是Global Transaction Identifier,可简化MySQL的主从切换以及Failover.GTID用于在binlog中唯一标识一个事务 ...

  10. 大数据学习--day05(嵌套循环、方法、递归)

    嵌套循环.方法.递归 图形打印 public static void main(String[]arg) { /** * * * * * * */ // 3 2 1 0 // 1 3 5 for(in ...