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

目录

框架

一个框架就是一个独立的网页

frameset: 框架组,用来布局框架

frame: 具体的一个框架,一般放在frameset中

iframe: 内联框架, 可以嵌入到其他网页的body中

切入 层层切入

switch_to.frame() # 只用切 iframe/frame 不用切frameset

  1. id
  2. name
  3. index
  4. 定位到的frame元素 find_element_by_id("parent")

切出

switch_to.parent_frame() # 跳到上级 多层框架推荐使用

switch_to.defaut_content() # 跳出所有 一层框架推荐使用 也可以用switch_to.parent_frame()跳出框架

示例

from selenium import webdriver
from time import sleep driver = webdriver.Chrome()
driver.maximize_window()
driver.get("http://115.28.108.130/control.html") # iframe: 内联框架, 可以嵌入到其他网页的正文中,
# frameset: 框架组,用来布局,可以嵌套,不能嵌入到body中,
# frame,框架,需要放到frameset中
# 只用切iframe及frame, frameset是用来布局的,不用切
driver.switch_to.frame("parent_frame")
driver.switch_to.frame("left")
driver.find_element_by_link_text("链接1").click() driver.switch_to.parent_frame() # 这里不用swith_to.default_content(),不然还要再切到parent_frame
driver.switch_to.frame("main")
print(driver.find_element_by_tag_name("h2").text)
# print(driver.find_element_by_xpath("/html/body/h2").text) sleep(5)
driver.quit()

练习

打开 http://115.28.108.130/control.html,点击链接1,输出右侧文本内容

注意

  1. 框架中的页面 尽量不要使用xpath绝对路径定位 /html/body/h2

xpath

  1. 绝对路径+索引 /html/body/div/form/div[3] 逐层写 结合index index从1开始
  2. 相对路径+属性(推荐) //div[@id="firstdiv"] 支持多属性结合定位
  3. 通过子标签 //div[a] 包含链接的div
  4. 通过文本定位 //[text()="第二个div"] 包含 //[contains(text(), "username")]
  5. 通过相对位置 //*[text()="第二个div"]/../table
  6. 轴 //[text()="王五"]/following::a following后面的

    //
    [text()="用户名"]/following::input 用户名后的第一个输入框

也可以通过F12复制(不推荐:有可能有问题)

注意:

  1. xpath的索引从1开始
  2. 使用文本定位 注意 换行 空格  特殊字符
  3. 注意动态位置,动态属性
  4. 注意复制的xpath可能会有问题

css selector

css选择器, 比xpath快

find_element_by_css_selector("#firstdiv")

基本

  1. id #firstdiv
  2. class .stuname
  3. 标签名 div *可以标识任意标签

位置 不支持向上

  1. 下级 #firstdiv>form>div >或空格
    • 同级元素
  2. 索引: :first-child() :nth-child(n) #firstdiv>form>div:nth-child(3)

属性 不支持判断文本

  1. 属性 [type="password"] [name=""]
  2. 属性 ^= 以 开头 $= 以 结尾 *= 包含
  3. input 常见属性: checked enabled

示例

from selenium import webdriver
from time import sleep driver = webdriver.Chrome()
driver.maximize_window()
driver.get("http://115.28.108.130/control.html") div = driver.find_element_by_css_selector("#firstdiv>form>div:nth-child(2)")
print(div.text)
table = driver.find_element_by_css_selector("#firstdiv>form>div+table")
print(table.tag_name)

练习:

打开 http://115.28.108.130/control.html#

  1. 找到"第二个div"并打印文本 text
  2. 找到"第二个div"同级的table并打印标签名 tag_name

注意:

  1. css selector不支持往上级查找
  2. 不支持查找包含某个子标签的标签
  3. 不支持查找指定文本内容的标签

切换窗口

  1. switch_to.alert(): 切到弹出框
  2. switch_to.frame(): 切入框架
  3. switch_to.window(): 切换窗口
  • window_handles: 所有窗口句柄 列表
  • current_window_handle: 当前窗口句柄

只有两个窗口

all = driver.window_handles  # 所有窗口句柄
old = driver.current_window_handle # 当前窗口出版 for h in all: # h 是当前从all中取出来的句柄
if h != old: # 如果取出来的不等于老窗口
driver.switch_to.window(h) # 切换到新窗口

多个窗口

all = driver.window_handles
for h in all:
driver.switch_to.window(h)
if "腾讯课堂" in driver.title:
break # 跳出循环

示例

from selenium import webdriver
from time import sleep driver = webdriver.Chrome()
driver.maximize_window()
driver.get("http://115.28.108.130/control.html") # 1. 切到新页面(只打开了两个页面)
driver.find_element_by_partial_link_text("在新页面").click()
print(driver.title) # 还在原页面
all = driver.window_handles
old = driver.current_window_handle
for h in all:
if h!=old:
driver.switch_to.window(h)
print(driver.title) # 切换到了新页面
driver.find_element_by_id("kw").send_keys("龙腾育才")
driver.find_element_by_id("su").click()
sleep(1)
driver.find_element_by_partial_link_text("腾讯课堂").click() # 又打开了新页面 # 2. 多窗口切换, 根据网页标题切换
print(driver.title) # 还在百度搜索页上 all = driver.window_handles
for h in all:
driver.switch_to.window(h)
if "腾讯课堂" in driver.title:
break
else:
print("没有找到相应的页面") print(driver.title) sleep(5)
driver.quit()

练习

打开百度 http://www.baidu.com

搜索赶集网

切换到赶集网,并打印标题

此为北京龙腾育才 Python高级自动化(Selenium部分)授课笔记

课程介绍

想要参加现场(北京)/网络课程的可以联系作者微信:lockingfree

  1. 高效学习,快速掌握Python自动化所有领域技能
  2. 同步快速解决各种问题
  3. 配套实战项目练习

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

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

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

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

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

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

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

  8. Jenkins持续集成项目搭建与实践——基于Python Selenium自动化测试(自由风格)

    Jenkins简介 Jenkins是Java编写的非常流行的持续集成(CI)服务,起源于Hudson项目.所以Jenkins和Hudson功能相似. Jenkins支持各种版本的控制工具,如CVS.S ...

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

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

随机推荐

  1. Dubbo实践(二)架构

    架构 节点角色说明 节点 角色说明 Provider 暴露服务的服务提供方 Consumer 调用远程服务的服务消费方 Registry 服务注册与发现的注册中心 Monitor 统计服务的调用次数和 ...

  2. js尾巴

    js中根据id获取标签: /** * 根据id获取标签 * @param {string}id * @returns {object} */ function $(id) { return typeo ...

  3. ts简单点

    typescript 简洁使用 *做最简洁核心的记录,可以节约时间.再是提炼概括,理解归纳.便于日后查阅联想* > typescript原则之一: 对值所具有的结构进行类型检查 #### 基础类 ...

  4. 2019 wishes

    1. 永恒目标:爱自己,依靠自己,全家人身心健康. 2. 投稿4篇+,发表2+,不管什么刊物,书稿交给出版社.//改动一下,尽量发高质量杂志和期刊. 3. 带着儿子一起学习怎么和别人主动打招呼,做个有 ...

  5. JDBC—执行sql语句的通用方法

    /* * 执行 sql的方法集 * delete,insert into ,update */ public static void update(String sql){ Connection co ...

  6. Angular7教程-03-Angular常用操作(上)

    本节来介绍angular中的操作以及TypeScript语法的简单介绍.关于TypeScript语法的更为详细的内容,打算在整个angular教程结束后再单独介绍. 0. 安装所需要的插件及配置插件 ...

  7. Token ,Cookie和Session的区别

    在做接口测试时,经常会碰到请求参数为token的类型,但是可能大部分测试人员对token,cookie,session的区别还是一知半解. Cookie cookie 是一个非常具体的东西,指的就是浏 ...

  8. 用JavaScript获取URL参数的方法之一

    若地址栏URL为:abc.html?m=tomms&c=allsearchlist&pageNo=1&pageNum=20&text=1 <script> ...

  9. js获取dom元素的子元素,父元素,兄弟元素小记

    原生jsvar a = document.getElementById("dom"); del_space(a); //清理空格 var b = a.childNodes; //获 ...

  10. 服务端接收不到ajax post请求的参数

    问题描述 服务端使用request.getParameter()接收不到post请求的参数,导致业务逻辑抛出空指针异常. 解决途径 tomcat对post请求支持的字节数不受限制的配置发生变化.在to ...