如有任何学习问题,可以添加作者微信: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. csv文件的使用,csv空白行问题

    首先w+和wb区别 两者都是用于以只写方式打开指定文件指定文件原来不存在,则在打开时由系统新建一个以指定文件名命名的文件,如果原来已存在一个以该文件名命名的文件,则在打开时将该文件删去,然后重新建立一 ...

  2. haproxy原理理解

    1.haproxy使用最需要注意的点: 1.1连接数: 前端maxconn默认值为2000,非常有必要将其增加几倍. 1.2超时时间 timeout connect 60s # haproxy和服务端 ...

  3. iOS dyld: Library not loaded 报错解决

    Xcode 用的是10.1 版本打的苹果包在 ios系统10.0 以上可以正常运行 但是系统9.3的手机安装后直接运行就崩溃 后来插上电脑联调 报错 dyld: Library not loaded: ...

  4. 淘宝商品放大镜效果-JavaScript

    效果图 HTML代码 <!DOCTYPE html> <html lang="en"> <head> <meta charset=&quo ...

  5. s3c2440存储控制器详解

    从上图可知,外部内存类的设备与存储管理器相连,那么CPU是怎样访问到内存的呢?通过存储管理器.CPU比较单纯,只会按照指令执行,CPU只负责发出地址,怎样找到内存类设备呢?这些都交给存储管理器来管理. ...

  6. css中元素的分类

    按照显示元素分类: 行内元素(lnline-element):元素的高度,行高,顶底边距由元素所包含的图片或文字所决定,不可改变:其宽度为内容文字或图片的宽度所决定,而其左右边距可人为设置. 行内元素 ...

  7. Java 访问控制规则简介

    1. 概述 老生常谈的内容 巩固一下自己 要摇摇欲坠的基础 内容确实不怎么高级... 2. 常规解释 1. 概述 简单说下什么情况 在单纯考虑 public, protected, 以及 privat ...

  8. WPF自定义命令

    WPF的自定义命令实现过程包括三个部分,定义命令.定义命令源.命令调用,代码实现如下: public partial class MainWindow : Window { public MainWi ...

  9. Linux入门第五天——shell脚本入门(下)基础语法之调试debug

    一.如何debug 1.通过sh命令的参数: sh [-nvx] scripts.sh 选项与参数: -n :不要执行 script,仅查询语法的问题: -v :再执行 sccript 前,先将 sc ...

  10. AWT之—画图

    package edu.ch4; import java.awt.Color;import java.awt.Font;import java.awt.Frame;import java.util.C ...