如有任何学习问题,可以添加作者微信: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. topk两种解法

    1.这个通过partition实现topk,时间复杂度是o(logn*logn),也就是0(n),但需要修改原数组的顺序 下面这个代码本身有一些错误,并且throw excption会在牛客上报错 c ...

  2. 20165302实验二java面向对象程序设计

    20165302实验二java面向对象程序设计 实验结果 提交点1 1.实验要求: 参考 (http://www.cnblogs.com/rocedu/p/6371315.html#SECUNITTE ...

  3. PHP扩展功能 ---- 页面静态化(OB缓冲)

    一.入门三部曲 1.什么是页面静态化 百度百科介绍: 静态页面是网页的代码都在页面中,不需要执行asp,php,jsp,.net等程序生成客户端网页代码的网页,静态页面网址中一般不含"?&q ...

  4. 服务器监控zabbix

    nagios服务器安装:http://www.jb51.net/article/79496.htm默认端口12489 nagios +ndo2db+mysqlhttps://www.cnblogs.c ...

  5. Linux TCP server 只能接受一个 TCP 连接

    #include <stdio.h> #include <sys/types.h> #include <sys/socket.h> #include <str ...

  6. Node 192.168.248.12:7001 is not empty. Either the node already knows other nodes (check with CLUSTER NODES) or contains some key in database 0.

    [root@node00 src]# ./redis-trib.rb add-node --slave --master-id4f6424e47a2275d2b7696bfbf8588e8c4c3a5 ...

  7. vue项目中分享到朋友圈,调用微信接口

    虽然微信提供了jssdk,不代表可以点击按钮进行分享到朋友圈,是需要微信自带的浏览器右上角进行分享.手机浏览器需要浏览器支持分享到朋友圈的分享机制. 微信jssdk地址: https://mp.wei ...

  8. iOS 12.0-12.1.2 越狱教程

    unc0ver V3.0.0~b29 越狱工具已经开始公测,支持搭载 A8X-A11 处理器的 iOS 12.0-12.1.2 设备完整越狱,Cydia 商店和 Substrate 插件可正常安装并运 ...

  9. Vue使用moment.js处理前端时间格式问题

    使用moment.js处理格式显示问题: 1.首先引入moment.js插件 npm install moment --save 2.入口文件main.js中导入并使用 3.在项目中使用即可:data ...

  10. 2.4 自己编写一个vivi驱动程序

    学习目标:从零编写一个vivi驱动程序,并测试: 一. vivi驱动应用程序调用过程 上节对xawtv对vivi程序调用欧城进行了详细分析,可总结为以下流程: 二.仿照vivi.c编写myvivi.c ...