如有任何学习问题,可以添加作者微信: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. 解决iOS项目根目录下文件乱七八糟的问题

    对于一个刚做项目的新手来说,肯定会碰到一个相当蛋疼的问题,那就是你在项目中建立的文件夹与你在根目录下的文件夹完全对应不起来,说直接点就是你通过group的方式在项目中建立的文件夹在本目录下根本就没有. ...

  2. Git如何从github上pull别人的项目

    1:使用git方式导入项目 菜单-File->import->Git->Projects from Git 2:选择某个服务器上的资源 3:选择需要pull的地址 后面需要自己加上 ...

  3. C#中Lambda表达式类型Expression不接受lambda函数

    在EF Core中我们经常会用System.Linq.Expressions系统命名空间的Expression<TDelegate>类型来作为EF Core的查询条件,比如: using ...

  4. HTML中的<meta>标签的使用

    HTML中<meta>标签的使用 在我们制作的网页中,要是想让它能够让更多的人去访问,最好的方法就是通过搜索引擎来找到你的网址,于是需要你的网页可以有关键词能够让搜索引擎来识别,于是HTM ...

  5. Spring入门第一课:Spring基础与配置Bean

    1.入门 Spring是简化java开发的一个框架,其中IoC和AOP是Spring的两个重要核心.由于Spring是非侵入性的,通过Ioc容器来管理bean的生命周期,还整合了许多其他的优秀框架,所 ...

  6. Python入门(案例)

    Python入门(案例) #一.上课案例: #输出hello wordprint('hello word') #python注释有两种#1.单行注释#这是单行注释#2.多行注释'''这是多行注释''' ...

  7. 【mongodb用户和身份认证管理】

    admin系统库用户管理 #移除 #查看 特定的数据库用户管理 #添加 #修改密码

  8. 第6章 HDFS HA配置

    目录 6.1 hdfs-site.xml文件配置 6.2 core-site.xml文件配置 6.3 启动与测试 6.4 结合ZooKeeper进行自动故障转移 在Hadoop 2.0.0之前,一个H ...

  9. 第一章:程序设计和C语言

    一.什么是计算机程序? 所谓程序就是一组计算机能识别和执行的指令.计算机的一切操作都是由程序控制的,本质是程序的机器,程序和指令是计算机系统最基本的概念. 二.什么是计算机语言? 人和计算机交流信息要 ...

  10. HyperLedger Fabric 1.4 生产环境使用ca生成msp和tls(12)

    在上一章:Fabric kafka生产环境部署的基础上部署Fabric CA,使用Fabric CA进行生成公私钥和证书等文件,全部替换cryptogen工具,包括生成TLS相关的私钥和证书等文件.  ...