常用库导入

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. uniapp 踩坑

    获取数据 可在 onLoad 生命周期中获取数据,接收一个参数 option 为上个页面传递的参数. 点击事件tap代替click 两者都会在点击时触发,但是在web手机端,clikc会有300ms延 ...

  2. springboot rabbitmq 找不到队列

    错误报告: org.springframework.amqp.rabbit.listener.BlockingQueueConsumer$DeclarationException: Failed to ...

  3. Jetson AGX Xavier安装TensorFlow

    参考https://docs.nvidia.com/deeplearning/frameworks/install-tf-jetson-platform/#prereqs 1. 安装系统包 sudo ...

  4. linux关于suid提权笔记

    suid全称是Set owner User ID up on execution.这是Linux给可执行文件的一个属性,上述情况下,普通用户之所以也可以使用ping命令,原因就在我们给ping这个可执 ...

  5. 仿站-获取网站的所有iconfont图标

    在仿站过程中,网站的iconfont查找非常浪费时间,这里教大家一次性获取网站iconfont的方法 1.打开 开发者工具 在element中搜索font-face,结果如下,复制font-face所 ...

  6. 04_CSS入门和高级技巧(2)

    上节课复习 HTML表格,table.tr.td(th):thead.tbody:caption. 一定要会根据图形,来写表格: <table border="1"> ...

  7. Python 为什么抛弃累赘的花括号,使用缩进来划分代码块?

    大家好,这是"Python为什么"系列节目的文字稿(文末有观看地址). 本期话题:Python 为什么使用缩进来划分代码块,而不像其它语言使用花括号 {} 或者 "end ...

  8. 【Hadoop离线基础总结】CDH版本的zookeeper环境搭建

    CDH版本的zookeeper环境搭建 下载 下载地址 http://archive.cloudera.com/cdh5/cdh/5/ 修改配置文件 创建ZooKeeper数据存放目录 mkdir - ...

  9. 【Linux系列汇总】小白博主的嵌入式Linux实战快速进阶之路(持续更新)

    我把之前在学习嵌入式Linux和工作中遇到问题和相关经验等,一起整理到这里,方便自己查阅和学习,温故而知新,如果能帮助到您,请帮忙点个赞: 本文的宗旨 嵌入式Linux 的项目通常需要一个团队来开发, ...

  10. 爬虫系列 一次采集.NET WebForm网站的坎坷历程

    今天接到一个活,需要统计人员的工号信息,由于种种原因不能直接连数据库 [无奈].[无奈].[无奈].采取迂回方案,写个工具自动登录网站,采集用户信息. 这也不是第一次采集ASP.NET网站,以前采集的 ...