常用库导入

from selenium import webdriver #导入webdriver模块

from selenium.webdriver.common.by import By # XPATH 定位模块

from selenium.webdriver.remote.webdriver import WebElement #引入对象

from selenium.webdriver.support import expected_conditions as EC #配合 WebDriverWait使用

from selenium.webdriver.support.wait import WebDriverWait #显示式等待

from selenium.webdriver.support.select import Select #下拉框操作由Select

from selenium.webdriver.common.action_chains import ActionChains 导入动作链类,可以存储鼠标动作,并一起执行

from selenium.webdriver.common.keys import Keys #键盘操作使用的Keys类,配合send_keys使用

expected_conditions类提供的预期条件判断的方法

title_is                            #判断当前页面的 title 是否完全等于(==)预期字符串,返回布尔值
title_contains                         #判断当前页面的 title 是否包含预期字符串,返回布尔值
presence_of_element_located                #判断某个元素是否被加到了 dom 树里,并不代表该元素一定可见
visibility_of_element_located                  #判断元素是否可见(可见代表元素非隐藏,并且元素宽和高都不等于 0)
visibility_of                       #同上一方法,只是上一方法参数为locator,这个方法参数是 定位后的元素
presence_of_all_elements_located             #判断是否至少有 1 个元素存在于 dom 树中。举例:如果页面上有 n 个元素的 class 都是’wp’,那么只要有 1 个元素存在,这个方法就返回 True
text_to_be_present_in_element               #判断某个元素中的 text 是否 包含 了预期的字符串
text_to_be_present_in_element_value              #判断某个元素中的 value 属性是否包含 了预期的字符串
frame_to_be_available_and_switch_to_it          #判断该 frame 是否可以 switch进去,如果可以的话,返回 True 并且 switch 进去,否则返回 False
invisibility_of_element_located              #判断某个元素中是否不存在于dom树或不可见
element_to_be_clickable                #判断某个元素中是否可见并且可点击
staleness_of                      #等某个元素从 dom 树中移除,注意,这个方法也是返回 True或 False
element_to_be_selected                #判断某个元素是否被选中了,一般用在下拉列表
element_selection_state_to_be             #判断某个元素的选中状态是否符合预期
element_located_selection_state_to_be         #跟上面的方法作用一样,只是上面的方法传入定位到的 element,而这个方法传入 locator
alert_is_present                   #判断页面上是否存在 alert

1.浏览器

创建浏览器对象  driver = webdriver.xxx()
窗口最大化    maximize_window()
获取浏览器尺寸  get_window_size()
设置浏览器尺寸  set_window_size()
获取浏览器位置  get_window_position()
设置浏览器位置  set_window_position(x,y)
关闭当前标签/窗口 close()
关闭所有标签/窗口  quit()

2.页面相关操作

请求某个url       driver.get(url)
刷新页面操作      refresh()
回退到之前的页面    back()
前进到之后的页面    forward()
获取当前访问页面url  current_url
获取当前浏览器标题   title
保存图片        get_screenshot_as_png()/get_screenshot_as_file(file)
网页源码        page_source

###############3.元素定位###############
id定位       driver.find_element_by_id(value)

name属性值定位  driver.find_element_by_name(value)

类名定位      driver.find_element_by_class_name(value)

标签名定位     driver.find_element_by_tag_name(value)

链接文本定位    driver.find_element_by_link_text(value)

部分链接文本    driver.find_element_by_partial_link_text(value)

xpath路径表达式  driver.find_element_by_xpath(value)

css选择器     driver.find_element_by_css_selector(value)

###############4.元素操作#########################

对元素的相关操作,一般要先获取到元素,再调用相关方法 element = driver.find_element_by_xxx(value)

点击操作    element.click()

清空输入框   element.clear()

输入框输入数据 element.send_keys(data)

获取文本内容(既开闭标签之间的内容)  element.text

获取属性值(获取element元素的value属性的值)  element.get_attribute(value)

#############5.鼠标和键盘操作#################

鼠标操作需要导入类,见第一部分,然后创建对象ActionChains(driver),键盘操作导入类见第一部分

鼠标右击

el = driver.find_element_by_xxx(value)

context_click(el)

鼠标双击

el = driver.find_element_by_xxx(value)

ActionChains(driver).double_click(el).perform()

鼠标悬停

el = driver.find_element_by_xxx(value)

ActionChains(driver).move_to_element(el).perform()

常用键盘操作

send_keys(Keys.BACK_SPACE) 删除键(BackSpace)

send_keys(Keys.SPACE) 空格键(Space)

send_keys(Keys.TAB) 制表键(Tab)

send_keys(Keys.ESCAPE) 回退键(Esc)

send_keys(Keys.ENTER) 回车键(Enter)

send_keys(Keys.CONTROL,‘a’) 全选(Ctrl+A)

send_keys(Keys.CONTROL,‘c’) 复制(Ctrl+C)

send_keys(Keys.CONTROL,‘x’) 剪切(Ctrl+X)

send_keys(Keys.CONTROL,‘v’) 粘贴(Ctrl+V)

##############6.弹出框操作###############
进入到弹出框中  driver.switch_to.alert()

接收警告     accept()

关闭警告     dismiss()

发送文本到警告框 send_keys(data)

############7.下拉框操作由Select#############
将定位到的下拉框元素传入Select类中  selobj = Select(element)

通过索引选择,index 索引从 0 开始  select_by_index()

通过值选择(option标签的一个属性值)  select_by_value()

通过文本选择(下拉框的值)  select_by_visible_text()

查看所有已选  all_selected_options

查看第一个已选  first_selected_option

查看是否是多选  is_multiple

查看选项元素列表  options

取消选择   deselect_by_index() /deselect_by_value()/ deselect_by_visible_text()

############8.滚动条操作#############

js = "window.scrollTo(x,y) " x为水平拖动距离,y为垂直拖动举例

driver.execute_script(js)

js= "var q=document.documentElement.scrollTop=n" n为从顶部往下移动滚动举例

driver.execute_script(js)

#############9.cookies操作##############
获取所有cookies  get_cookies()

获取key对应的值  get_cookie(key)

设置cookies  add_cookie(cookie_dict)

删除指定名称的cookie  delete_cookie(name)

删除所有cookie  delete_all_cookies()

################10.多标签/多窗口、多表单/多框架切换#############
多表单/多框架切换
直接使用id值切换进表单   driver.switch_to.frame(value)

定位到表单元素,再切换进入
el = driver.find_element_by_xxx(value)

driver.switch_to.frame(el)

跳回最外层的页面  driver.switch_to.default_content()
跳回上层的页面  driver.switch_to.parent_frame()
多标签/多窗口之间的切换
获取所有窗口的句柄   handles = driver.window_handlers
通过窗口的句柄进入的窗口  driver.switch_to.window(handles[n])

web selenium 小笔记的更多相关文章

  1. WEB学习小笔记

    环境基于WIN10.IDEA最新版.JDK1.8.TOMCAT9 下面说的有错的地方希望指出,谢谢. STRUT2 1.在maven下的时候系统会系统创建一个叫做log4j的配置文件,但是到了这个版本 ...

  2. 【前端】移动端Web开发学习笔记【1】

    下一篇:移动端Web开发学习笔记[2] Part 1: 两篇重要的博客 有两篇翻译过来的博客值得一看: 两个viewport的故事(第一部分) 两个viewport的故事(第二部分) 这两篇博客探讨了 ...

  3. web前端学习笔记

    web前端学习笔记(CSS盒子的定位) 相对定位 使用相对定位的盒子的位置常以标准流的排版方式为基础,然后使盒子相对于它在原本的标准位置偏移指定的距离.相对定位的盒子仍在标准流中,它后面的盒子仍以标准 ...

  4. selenium课程笔记

    selenium课程笔记第一天(2017-7-1) 一.配置火狐浏览器 运行:firefox.exe -p -no -remote selenium课程笔记第二天 用Eclipse+java+sele ...

  5. web前端开发笔记(1)

     一.HTML标签书写有哪些规范? 页面编码. 文档声明. 关键字与描述. 行内元素不能包含块级元素. a标签不能嵌套a标签. 标签名和属性必须用小写字母书写,属性必须加引号,标签必须闭合,单标签页必 ...

  6. java selenium 自动化笔记-不是0基础,至少有java基础

    本来今天要学GitHub的,但是在群里问了下小伙伴时被暴击.说我学的东西太多太杂,不是很深入,都是皮毛.哎~自己早深有意识到,因个人能力吧,找的资料都不是很全,加上实际工作没有应用到.所以写一篇sel ...

  7. Web安全学习笔记 SQL注入下

    Web安全学习笔记 SQL注入下 繁枝插云欣 --ICML8 SQL注入小技巧 CheatSheet 预编译 参考文章 一点心得 一.SQL注入小技巧 1. 宽字节注入 一般程序员用gbk编码做开发的 ...

  8. 【前端】移动端Web开发学习笔记【2】 & flex布局

    上一篇:移动端Web开发学习笔记[1] meta标签 width设置的是layout viewport 的宽度 initial-scale=1.0 自带 width=device-width 最佳实践 ...

  9. 【前端】Web前端学习笔记【2】

    [2016.02.22至今]的学习笔记. 相关博客: Web前端学习笔记[1] 1. this在 JavaScript 中主要有以下五种使用场景 在全局函数调用中,this 绑定全局对象,浏览器环境全 ...

随机推荐

  1. Java中的动态定义数组

    1.一维矩阵的动态定义(代码注释) 1.1方法一 package dongtai; import java.util.Scanner; import java.util.ArrayList; publ ...

  2. php5与php7安全性的区别

    0X01 前言 本篇文章大多为转载,但是修正了一些不正确的说法,对某些功能点的变更指出具体是哪个版本变更,加入了一些小更新. (原文地址:https://www.freebuf.com/article ...

  3. Spring Cloud学习 之 Spring Cloud Hystrix(断路器原理)

    断路器定义: public interface HystrixCircuitBreaker { // 每个Hystrix都通过它判断是否被执行 public boolean allowRequest( ...

  4. 13_JavaScript基础入门(3)

    条件分支语句 条件分支语句,也叫作条件判断语句,就是根据某种条件执行某些语句,不执行某些语句. JS中有三种语法是可以表示条件分支的. 1.if--else-- 条件分支的主力语法,这个主力语法能够书 ...

  5. Vue + Element-ui实现后台管理系统(3)---面包屑 + Tag标签切换功能

    面包屑 + Tag标签切换功能 有关后台管理系统之前写过两遍博客,看这篇之前最好先看下这两篇博客.另外这里只展示关键部分代码,项目代码放在github上: mall-manage-system 1.V ...

  6. Spring Cloud认知学习(一):Spring Cloud介绍与Eureka使用

    目录 Spring Cloud的介绍 微服务的介绍 Spring Cloud出现的原因: 常见场景: 微服务的优劣势: Spring Cloud版本问题 版本介绍 与Spring Boot版本对应关系 ...

  7. VMware Centos7 桥接 DHCP无法获得IP

    问题描述 VMware Centos7 桥接模式下,虚拟机无法获得IP,无法联网 解决方案 网络设置为DHCP自动获取IP 查看主机(不是虚拟机)的相关服务是否打开,主要是VMware DHCP 这个 ...

  8. java-> 利用IO操作与递归实现目录的复制

    public class CopyDir { public static void main(String[] args) { copyDir(new File("d:\\a"), ...

  9. Python 常用编码规范

    一.简明概述 1.编码 如无特殊情况, 文件一律使用 UTF-8 编码 如无特殊情况, 文件头部必须加入#-*-coding:utf-8-*-标识 2.代码格式 2.1.缩进 统一使用 4 个空格进行 ...

  10. Node教程——API接口开发(Node版的CRUD通用接口的搭建)(MangoDB+Express_Version2)

    1. 概述 时间跨度有点大,之前就跟大家唠嗑过一些知识点,也开启了一个Node书写一个后台api项目的开始,出于各种原因,迟迟没有更新博文.现在我把这个坑填上,如果你还有阅读过我之前的文章,我建议你先 ...