selenium+常见操作

1.多窗口操作

有些页面的链接打开后,会重新打开一个窗口,对于这种情况,想在新页面上操作,就得先切换窗口了。获取窗口的唯一标识用句柄表示,所以只需要切换句柄,我们就能在多个页面上灵活自如的操作了。

句柄(handle):识别浏览器窗口的属性

获取当前窗口的句柄:driver.current_window_handle

获取当前所以的句柄:driver.current_window_handles

切换窗口:switch_to.window(all_h[1])(其中all_h[1]为需要访问窗口的句柄)

from selenium import webdriver
driver = webdriver.Chrome()
driver.get("http://bj.ganji.com/")
h = driver.current_window_handle
driver.maximize_window()
print (h)  # 打印首页句柄
driver.find_element_by_link_text("工作").click()
all_h = driver.window_handles
print (all_h)     # 打印所有的句柄
#获取list里面第二个直接切换
driver.switch_to.window(all_h[1])
print (driver.title)
# 关闭新窗口
#driver.close()
# 切换到首页句柄
driver.switch_to.window(h)
# 打印当前的title
print (driver.title)

2.下拉框操作

1. 基本思路:先定位select框,再定位select里的选项

定位select中的选项可以通过以下几种方式:

select_by_index()  :通过索引定位
       select_by_value()  :通过value值定位
       select_by_visible_text() :通过文本值定位
       deselect_all()          :取消所有选项
       deselect_by_index()     :取消对应index选项
      deselect_by_value()      :取消对应value选项
      deselect_by_visible_text() :取消对应文本选项
      first_selected_option()  :返回第一个选项
      all_selected_options()   :返回所有的选项

eg:s = driver.find_element_by_id(" ")

Select(s).select_by_visible_text(" ")

   2.直接通过xpath定位

eg:driver.find_element_by_xpath(" ").click()

from selenium import webdriver
from selenium.webdriver.support.ui import Select
import time
driver = webdriver.Chrome()
driver.get(‘http://sahitest.com/demo/selectTest.htm‘)
time.sleep(1)
s1 = Select(driver.find_element_by_id(‘s1Id‘))  # 实例化Select
time.sleep(1)
s1.select_by_index(1)  # 选择第二项选项:o1
time.sleep(1)
s1.select_by_value("o2")  # 选择value="o2"的项
time.sleep(1)
s1.select_by_visible_text("o3")  # 选择text="o3"的值,即在下拉时我们可以看到的文本
time.sleep(1)

三.弹出框的操作

弹出框基本为三种:alert(只有确定按钮和x的按钮)\confirm(比alert多个取消的按钮)\promp(内含文本框)

  alert操作:

1.先用switch_to_alert()方法切换到alert弹出框上

2.可以用text方法获取弹出的文本 信息

3.accept()点击确认按钮

4.dismiss()相当于点右上角x,取消弹出框

confirm操作:

1.先用switch_to_alert()方法切换到alert弹出框上

2.可以用text方法获取弹出的文本 信息

3.accept()点击确认按钮

4.dismiss()相当于点取消按钮或点右上角x,取消弹出框

prompt操作

1.先用switch_to_alert()方法切换到alert弹出框上

2.可以用text方法获取弹出的文本 信息

3.accept()点击确认按钮

4.dismiss()相当于点右上角x,取消弹出框

5.send_keys()这里多个输入框,可以用send_keys()方法输入文本内容

四.滚动条操作

滚动条是无法直接用定位工具来定位的。selenium里面也没有直接的方法去控制滚动条,

这时候只能借助Js了,还好selenium提供了一个操作js的方法:

execute_script(),可以直接执行js的脚本。

scrollTo(x, y),第一个参数x是横向距离,第二个参数y是纵向距离

1.#滚动到底部
    js = "window.scrollTo(0,document.body.scrollHeight)"
    driver.execute_script(js)

2.#滚动到顶部
     js = "window.scrollTo(0,0)"
    driver.execute_script(js)

from selenium import webdriverimport timedriver = webdriver.Chrome()driver.get("http://www.cnblogs.com/fenhong/")#print (driver.name)#滚动到底部js = "window.scrollTo(0,document.body.scrollHeight)"driver.execute_script(js)time.sleep(10)#滚动到顶部js = "window.scrollTo(0,0)"driver.execute_script(js)

五.元素聚焦
   1.虽然用上面的方法可以解决拖动滚动条的位置问题,但是有时候无法确定我需要操作的元素

在什么位置,有可能每次打开的页面不一样,元素所在的位置也不一样,怎么办呢?

2.这个时候我们可以先让页面直接跳到元素出现的位置,然后就可以操作了。同样需要借助JS去实现。
   3.元素聚焦:

target = driver.find_element_by_xxxx()
   driver.execute_script("arguments[0].scrollIntoView();", target)

六.单选框,多选框操作

判断是否选中:is_selected()

选择的操作就直接定位到需要选择的框然后click()一下就好;全选时可以获取全部的选择框然后循环click()。

原文地址:https://www.cnblogs.com/fenhong/p/9176673.html

时间: 2024-10-09 21:19:20

selenium+常见操作的相关文章

selenium 常见操作,使用 Keys 类来进行键盘的按键操作

在平常我们使用百度查询时一般会使用 回车键(enter) Keys 类里面的常用方法行为: 回车键:Keys.ENTER 删除键:Keys.BACK_SPACE 空格键:Keys.SPACE 回退键:Keys.ESCAPE 刷新键:Keys.F5 键盘操作需要引入: from selenium.webdriver.common.keys import Keys 示例:我们就以百度查询,按回车为例 from selenium import webdriver import time from se

selenium 常见操作,js操作-将元素滚动到页面可见区域

我们在自动化测试中,会遇到需要把浏览器页面的元素移动到可见区域,就需要使用页面向上或者向下滚动 js操作-滚动条:使用: selenium 当中使用 execute_script   (译:埃克斯Q特.思怪泼特) 方法 执行 js 语句: 页面元素滚动到可见区域常用的操作: 1.移动到元素element对象的“底端”与当前窗口的“底部”对齐: driver.execute_script("arguments[0].scrollIntoView(false);",element) 2.移

selenium 常见操作,使用 js 操作-日期框及文本框

在使用 selenium 对页面进行相关操作时,有时候会遇到以下三种情况: 1.日期框:无法直接输入文本,必须要选择某一天的日期并点击才会填入文本框; 2.检索框:可以直接输入文本,但必须要点击根据输入的文本检索出来的下拉列表的某-项; 3.置灰的文本框:无法直接输入文本 按照常规套路,我们通常都会采取各种元素定位方法按照操作步骤一步步来实现 ,但是遇到上面三种奇葩,页面定位操作就显得有些捉襟见肘了,因此我们可以通过 selenium 中的 javascript 操作来处理它. 我们以12306

selenium 常见操作,上传操作

上传操作有两种情况: 第一种:如果是 input 可以直接输入路径的,那么直接调send_ keys输入路径 第二种:非 inpat 标签的上传,则需要借助第三方工具,有一下三种方法 2.1 Autolt 我们去调用其生成的 au3 或 exe 文件: 2.2 SendKeys 第 三方库(目前只支持到2.7版本),目前因为这个库不在维护,需要要使用的话需要更改源代码,所以我们不用这种方法 网址: https://pypi.org/project/SendKeys/ 2.3 Python 的 p

selenium 常见元素操作:三大等待

selenium 常见元素操作 三大等待 三大切换(iframe,window,alert) 下拉列表 鼠标和键盘 js+ dom应用() 上传操作 强制等待:time.sleep()        (译:私立破) 必须等待固定时间后才可以往下运行 from selenium import webdriver import time # 强制等待需要导入time,使用其中的sleep方法 # 强制等待 sleep(译:私立破) # 打开谷歌浏览器,建立会话.启动Chromedriver.exe

C#路径/文件/目录/I/O常见操作汇总

文件操作是程序中非常基础和重要的内容,而路径.文件.目录以及I/O都是在进行文件操作时的常见主题,这里想把这些常见的问题作个总结,对于每个问题,尽量提供一些解决方案,即使没有你想要的答案,也希望能提供给你一点有益的思路,如果你有好的建议,恳请能够留言,使这些内容更加完善. 主要内容:一.路径的相关操作, 如判断路径是否合法,路径类型,路径的特定部分,合并路径,系统文件夹路径等内容:二.相关通用文件对话框,这些对话框可以帮助我们操作文件系统中的文件和目录:三.文件.目录.驱动器的操作,如获取它们的

【代码学习】MYSQL数据库的常见操作

============================== MYSQL数据库的常见操作 ============================== 一.mysql的连接与关闭 -h:指定所连接的服务器位置 -u:数据库的用户名 -p:数据库的密码 1 mysql -u 用户名 -p //连接数据库 2 密码 3 exit //关闭数据库 1 mysql_connect($host,$user,$password); //连接数据库 2 mysql_close() //关闭数据库 二.创建数据

杂【第一天】包括eclipse常见操作,程序调试模式

观看传智播客视频笔记,感谢 eclipse的常见操作: 1.当即热版本低于编译器版本是,会出现bad Vresion number in class file的错误: 2.快捷键: alt+/:模板键 ctrl+1:快速修复 ctrl+shift+o:导包 设置代码阿保存的时候自动格式化:windows->首选项->Java->Editor->save Actions 代码移动:alt+上下键 重置视图:window->reset perspective... 3.典型的字节

[java学习笔记]java语言基础概述之数组的定义&常见操作(遍历、排序、查找)&二维数组

1.数组基础 1.什么是数组:           同一类型数据的集合,就是一个容器. 2.数组的好处:           可以自动为数组中的元素从零开始编号,方便操作这些数据. 3.格式:  (一旦创建,必须明确长度)          格式1:              元素类型   [ ]  数组名  =  new  元素类型  [元素个数即数组的长度]:              示例:int[] array = new int[5];          格式2: