如有任何学习问题,可以添加作者微信: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. VMware ESXi 6.5安装

    vmware ESXI6.5安装 注意:我是用vmware模拟,选择镜像就可以进入.正常需要服务器做raid 然后安装的时候选择需要的硬盘 等待加载 按enter继续 F11同意并继续 等待扫描设备 ...

  2. UglifyJS 压缩选项

    UglifyJS 压缩选项 1.使用逗号运算符连接简单语句 2.使用点符号代替中括号属性     foo [“bar”]→foo.bar 3.删除逻辑上走不到的代码 4.删除调试代码    debug ...

  3. python-正则基础

    正则表达式,说的简单些,就是一个匹配的功能,在python中,只要引用 re 模块,就能进行正则匹配操作 一.math匹配 先来看一个简单的例子 import re re.match(pattern, ...

  4. 【题解】POJ 3417 Network(倍增求LCA+DP+树上差分)

    POJ3417:http://poj.org/problem?id=3417 思路 我们注意到由“主要边”构成一颗树 “附加边”则是非树边 把一条附加边(x,y)加入树中 会与树上x,y之间构成一个环 ...

  5. EF Core中Key属性相同的实体只能被跟踪(track)一次

    在EF Core的DbContext中,我们可以通过DbContext或DbSet的Attach方法,来让DbContext上下文来跟踪(track)一个实体对象,假设现在我们有User实体对象,其U ...

  6. Many-to-many relationships in EF Core 2.0 – Part 3: Hiding as ICollection

    In the previous post we ended up with entities that hide the join entity from the public surface. Ho ...

  7. Intermediate_JVM 20180306 : 运行时数据区域

    Java比起C++一个很大的进步就在于Java不用再手动控制指针的delete与free,统一交由JVM管理,但也正因为如此,一旦出现内存溢出异常,不了解JVM,那么排查问题将会变成一项艰难的工作. ...

  8. mysql 使用order by

    1.mysql 使用order by field() 自定义排序 order by field(value,str1,str2,str3,str4......strn) 例如:select * fro ...

  9. c++基础STL

    今天给大家介绍几个容器,包含的头文件为<vector>,<stack>,<queue>,<map>,<list>,<deque> ...

  10. 最优贸易(tarjan,spfa)

    题目描述 C国有n个大城市和m 条道路,每条道路连接这 n个城市中的某两个城市.任意两个城市之间最多只有一条道路直接相连.这 m 条道路中有一部分为单向通行的道路,一部分为双向通行的道路,双向通行的道 ...