Python Selenium 常用方法总结

  • 1.获取当前页面的Url
方法:current_url
实例:driver.current_url

  • 2.获取元素坐标
方法:location
解释:首先查找到你要获取元素的,然后调用location方法
实例:driver.find_element_by_xpath("xpath").location

  • 3.表单的提交
方法:submit
解释:查找到表单(from)直接调用submit即可
实例:driver.find_element_by_id("form1").submit()

  • 4.获取CSS的属性值
方法:value_of_css_property(css_name)
实例:driver.find_element_by_css_selector("input.btn").value_of_css_property("input.btn")

  • 5.获取元素的属性值
方法:get_attribute(element_name)
实例:driver.find_element_by_id("kw").get_attribute("kw")

  • 6.判断元素是否被选中
方法:is_selected()
实例:driver.find_element_by_id("form1").is_selected()

  • 7.返回元素的大小
方法:size
实例:driver.find_element_by_id("iptPassword").size
返回值:{‘width‘: 250, ‘height‘: 30}

  • 8.判断元素是否显示
方法:is_displayed()
实例:driver.find_element_by_id("iptPassword").is_displayed()

  • 9.判断元素是否被使用
方法:is_enabled()
实例:driver.find_element_by_id("iptPassword").is_enabled()

  • 10.获取元素的文本值
方法:text
实例:driver.find_element_by_id("iptUsername").text

  • 11.元素赋值
方法:send_keys(*values)
实例:driver.find_element_by_id("iptUsername").send_keys(‘admin‘)

  • 12.返回元素的tagName
方法:tag_name
实例:driver.find_element_by_id("iptUsername").tag_name

  • 13.删除浏览器所有的cookies
方法:delete_all_cookies()
实例:driver.delete_all_cookies()

  • 14.删除指定的cookie
方法:delete_cookie(name)
实例:deriver.delete_cookie("my_cookie_name")

  • 15.关闭浏览器
方法:close()
实例:driver.close()

  • 16.关闭浏览器并且退出驱动程序
方法:quit()
实例:driver.quit()

  • 17.返回上一页
方法:back()
实例:driver.back()

  • 18.清空输入框
方法:clear()
实例:driver.clear()

  • 19.浏览器窗口最大化
方法:maximize_window()
实例:driver.maximize_window()

  • 20.查看浏览器的名字
方法:name
实例:drvier.name

  • 21.返回当前会话中的cookies
方法:get_cookies()
实例:driver.get_cookies()

  • 22.根据cookie name 查找映射Value值
方法:driver.get_cookie(cookie_name)
实例:driver.get_cookie("NET_SessionId")

  • 23.截取当前页面
方法:get_screenshot_as_file(filename)
实例:driver.get_screenshot_as_file("D:\\Program Files\\Python27\\NM.bmp")

  • 24.获取当前窗口的坐标
方法:get_window_position()
实例:driver.get_window_position()

  • 25.获取当前窗口的长和宽
方法:get_window_size()
实例:driver.get_window_size()


ActionChains类鼠标操作的常用方法:

引入ActionChains类:from selenium.webdriver.common.action_chains import ActionChains
  • 26.右击
方法:context_click()
实例:ActionChains(driver).context_click(driver.find_element_by_id("id")).perform()

  • 27.双击
方法:double_click()
实例:ActionChains(driver).double_click(driver.find_element_by_name("name")).perform()

  • 28:鼠标拖放
方法:drag_and_drop(source, target)
     source:鼠标按下的源元素;target:鼠标释放的目标元素
实例:element = driver.find_element_by_name("name")
     target = driver.find_element_by_name("name")
     ActionChains(driver).drag_and_drop(element, target).perform()

  • 29:鼠标悬停在一个元素上(hover)
方法:move_to_element()
实例:above = driver.find_element_by_xpath("xpath路径")
      ActionChains(driver).move_to_element(above).perform()

  • 30:按下鼠标左键在一个元素上
方法:click_and_hold()
实例:left = driver.find_element_by_name("name")
     ActionChains(driver).click_and_hold(left).perform()


键盘事件:

引入Keys类包:from selenium.webdriver.common.keys import Keys

  • 31:输入
方法:send_keys()
实例:driver.find_element_by_id("id").send_keys("XXX")

  • 32:输入空格
方法:send_keys(Keys.SPACE)
实例:driver.find_element_by_id("id").send_keys(Keys.SPACE)

  • 33:ctrl + a 
    全选输入框的内容 
    ctrl + x 
    剪切输入框的内容 
    ctrl + v 
    粘贴到输入框 
    ctrl + c 
    复制
方法:send_keys(Keys.CONTROL,‘a‘)
实例:driver.find_element_by_id("id").send_keys(Keys.CONTROL,‘a‘)

  • 34:回车代替点击
方法:send_keys(Keys.ENTER)
实例:driver.find_element_by_id("id").send_keys(Keys.ENTER)

  • 35:制表键(Tab)
方法:send_keys(Keys.TAB)
实例:driver.find_element_by_id("id").send_keys(Keys.TAB)

  • 36:回退键(Esc)
方法:send_keys(Keys.ESCAPE)
实例:driver.find_element_by_id("id").send_keys(Keys.ESCAPE)

等待时间

导入 WebDriverWait 包 
from selenium.webdriver.support.ui import WebDriverWait 
导入 time 包 
import time

  • 37:固定等待时间
方法:sleep()
实例:time.sleep(5)  # 等待5秒

  • 38:等待一个元素被发现,或一个命令完成,超出了设置时间则抛出异常智能等待。
方法:implicitly_wait()
实例:driver.implicitly_wait(30)

  • 39:在设置时间内,默认每隔一段时间检测一次当前页面元素是否存在,如果超过设置时间检测不到则抛出异常
"方法:WebDriverWait()"

#WebDriverWait(driver, timeout, poll_frequency=0.5, ignored_exceptions=None)
#——driver:WebDriver的驱动程序(Ie, Firefox, Chrome或远程)
#——timeout:最长超时时间,默认以秒为单位
#——poll_frequency:休眠时间的间隔(步长)时间,默认为0.5秒
#——ignored_exceptions:超时后的异常信息,默认情况下抛NoSuchElementException异常

实例:
element = WebDriverWait(driver, 10).until(lambda x: x.find_element_by_id("id"))

#一般由unit()或until_not()方法配合使用,同上:

调用该方法提供的驱动程序作为一个参数,直到返回值不为False。
——until(method, message=’’)

调用该方法提供的驱动程序作为一个参数,直到返回值为False。
——until_not(method, message=’’)

# 还可以与expected_conditions 一起使用
from selenium.webdriver.support import expected_conditions as EC

# 实例: 判断某个元素是否可见并且是enable的,这样才clickable

WebDriverWait(dr,15,1).until(EC.element_to_be_clickable((By.ID,"EmployeeListMenu")),"Not Find element")

  • 40:选择当前页面上所有tag
name为input的元素
inputs = driver.find_elements_by_tag_name(‘input‘)

  • 41:从中过滤出type为checkbox的元素,并勾选上
for input in inputs:
    if input.get_attribute(‘type‘) == ‘checkbox‘:
        input.click()

  • 42:使用CSS定位选择所有type为checkbox的元素,并勾选上
checkboxes = driver.find_elements_by_css_selector(‘input[type = checkbox]‘)
for checkbox in checkboxes:
      checkbox.click()

  • 43:把最后一个checkbox的勾去掉,pop()方法空参数时,默认移除list中的最后一个元素。
driver.find_elements_by_css_selector(‘input[type = checkbox]‘).pop().click()


切换活动对象

  • 44:切换浏览器handle
# 切换不同的tab页
方法:driver.switch_to.window(window_name)
# 备注:从A页跳转到B页,句柄已经切换过去,但是焦点没有切过去,所以需要switch_to.window,把焦点也切过去,才可以在当前页进行操作。
# 切换是思路,获取所有的句柄,因为返回是一个list,而且要切换的对象都是最后一个,可以使用[-1]直接切过去
# 例如:
driver.switch_to.window(driver.window_handles[-1])
  • 45:返回上一级表单
方法: driver.switch_to_parent_content()#旧方法
      driver.switch_to.parent_content#新方法

  • 46:返回最外层表单
方法: driver.switch_to_default_content()#旧方法
      driver.switch_to.default_content()#新方法

  • 47:切换到指定frame中
方法:driver.switch_to.frame(‘xxx‘)
实例:driver.switch_to.frame(‘frame_name‘)
     driver.switch_to.frame(index)
     driver.switch_to.frame(driver.find_elements_by_tag_name("iframe")[0])        

  • 48:获取当前page的title
方法:driver.title
实例:driver.title

  • 49:焦点切换到弹窗。
方法:driver.switch_to_alert()
实例:driver.switch_to_alert()

  • 50:前进
方法:
driver.forward()   

  • 51:刷新页面
方法:driver.refresh() 
时间: 2024-11-03 22:35:36

Python Selenium 常用方法总结的相关文章

Python Selenium 常用方法总结(不断补充)

还有此篇内容也丰富Selenium常见元素定位方法和操作的学习介绍 selenium Python 总结一些工作中可能会经常使用到的API. 1.获取当前页面的Url 方法:current_url 实例:driver.current_url 2.获取元素坐标 方法:location 解释:首先查找到你要获取元素的,然后调用location方法 实例:driver.find_element_by_xpath("xpath").location 3.表单的提交 方法:submit 解释:查

python selenium API 常用方法

配置使用环境 下载相应的浏览器驱动, Firefox 是默认的 本文以 chrome 为主 ,放在scripts目录下ChromeDriver 官方下载地址 : 所有版本的 ChromeDriver 文档参考 简明 Python 教程 Python教程 - 廖雪峰 官方文档 : Selenium with Python webdriver实用指南python版本 一份简单的测试 demo 关于 360 haosou.com 的测试 : 1 #coding=utf-8 2 from seleniu

WEB自动化(Python+selenium)的API

在做Web自动化过程中,汇总了Python+selenium的API相关方法,给公司里的同事做了第二次培训,分享给大家                                                                                                                     WEB自动化测试培训2 课程目的 一.Webdriver API 的使用 课程内容 1    控制浏览器 Selenium 主要提供的是操作页面上各

《一头扎进》系列之Python+Selenium框架实战篇4- 价值好几K的框架,呵!这个框架有点意思啊!!!

1.简介 前面文章,我们实现了框架的一部分功能,包括日志类和浏览器引擎类的封装,今天我们继续封装一个基类和介绍如何实现POM.关于基类,是这样定义的:把一些常见的页面操作的selenium封装到base_page.py这个类文件,以后每个POM中的页面类,都继承这个基类,这样每个页面类都有基类的方法,这个我们会在这篇文章由宏哥实现. 2.项目层级结构 1. 上一篇中我们已经创建好了项目层级结构,具体项目层级结构如下图.这里不再赘述,相关文件也如下: 3. 定位和截图类封装 1. 在实现封装基类里

【Selenium02篇】python+selenium实现Web自动化:鼠标操作和键盘操作!

一.前言 最近问我自动化的人确实有点多,个人突发奇想:想从0开始讲解python+selenium实现Web自动化测试,请关注博客持续更新! 这是python+selenium实现Web自动化第二篇博文 二.Selenium第一篇博文地址: [Selenium01篇]python+selenium实现Web自动化:搭建环境,Selenium原理,定位元素以及浏览器常规操作! 三.Selenium之鼠标操作和键盘操作 1.鼠标事件 在webdriver中,鼠标操作的方法封装在 ActionChai

Python Selenium 文件上传(二)

今天补充一种文件上传的方法 主要是因为工作中使用SendKeys方法不稳定,具体方法见: Python Selenium 文件上传(一) 这种方法直接通过命令行执行脚本时没有问题,可以成功上传,但是如果通过saltstack 远程控制执行时,SendKeys就定位不到窗口了. 所以采用这种新的方式来实现文件上传功能,并完美的解决了这个问题. 具体操作步骤如下: 1.下载工具 AutoIt及使用 AutoIt目前最新是v3版本,这是一个使用类似BASIC脚本语言的免费软件,它设计用于Windows

Python Selenium 文件上传(一)

昨天写了Web 文件下载的ui自动化,下载之后,今天就要写web 文件上传的功能了. 当然从折腾了俩小时才上传成功.下面写一下自己操作的步骤 首先网上说的有很多方法 如 input 标签的最好做了,直接定位到元素,然后再sendKeys("value")即可 <input id="file_name" class="text-1 w255" type="text" readonly="" value=

转 Python Selenium设计模式-POM

前言 本文就python selenium自动化测试实践中所需要的POM设计模式进行分享,以便大家在实践中对POM的特点.应用场景和核心思想有一定的理解和掌握. 为什么要用POM 基于python selenium2开始UI级自动化测试并不是多么艰巨的任务.只需要定位到元素,执行对应的操作即可.下面我们看一下这个简单的脚本实现百度搜索. from selenium import webdriver import time driver = webdriver.Firefox() driver.i

Python+selenium自动化公共逻辑步骤封装

开篇 个人博客"Python+selenium的GUI自动化实现"提到的chrome与IE浏览器调用插件已上传至51CTO下载,对应链接分别为:chrome,http://down.51cto.com/data/2171584:IE,http://down.51cto.com/data/2171585:有需要的直接下载即可:  正文 关于自动化,其实质就是用机器操作代替手工执行,从而减少人力投入.节约项目运营成功.优秀的自动化框架,可能的一个发展过程,前期自动化用例写作实现过程,可能需