selenium Python 总结一些工作中可能会经常使用到的API。

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()

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

  1. Python+selenium常用方法(Webdriver API)

    小编整理了目前学习的Python+selenium常用的一些方法函数,以后有新增再随时更新. 加载浏览器驱动: webdriver.Firefox() 打开页面:get() 关闭浏览器:quit() ...

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

    还有此篇内容也丰富Selenium常见元素定位方法和操作的学习介绍 selenium Python 总结一些工作中可能会经常使用到的API. 1.获取当前页面的Url 方法:current_url 实 ...

  3. 转载——Python Selenium 常用方法总结

    selenium Python 总结一些工作中可能会经常使用到的API. 1.获取当前页面的Url 方法:current_url 实例:driver.current_url 2.获取元素坐标 方法:l ...

  4. Python Selenium Webdriver常用方法总结

    Python Selenium Webdriver常用方法总结 常用方法函数 加载浏览器驱动: webdriver.Firefox() 打开页面:get() 关闭浏览器:quit() 最大化窗口: m ...

  5. python selenium API 常用方法

    配置使用环境 下载相应的浏览器驱动, Firefox 是默认的 本文以 chrome 为主 ,放在scripts目录下ChromeDriver 官方下载地址 : 所有版本的 ChromeDriver ...

  6. WEB自动化(Python+selenium)的API

    在做Web自动化过程中,汇总了Python+selenium的API相关方法,给公司里的同事做了第二次培训,分享给大家                                         ...

  7. Python+Selenium(webdriver常用API)

    总结了Python+selenium常用的一些方法函数,以后有新增再随时更新: 加载浏览器驱动: webdriver.Firefox() 打开页面:get() 关闭浏览器:quit() 最大化窗口:  ...

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

    1.简介 前面文章,我们实现了框架的一部分功能,包括日志类和浏览器引擎类的封装,今天我们继续封装一个基类和介绍如何实现POM.关于基类,是这样定义的:把一些常见的页面操作的selenium封装到bas ...

  9. Python+Selenium基础入门及实践

    Python+Selenium基础入门及实践 32018.08.29 11:21:52字数 3220阅读 23422 一.Selenium+Python环境搭建及配置 1.1 selenium 介绍 ...

随机推荐

  1. 使用jaxb根据xsd逆向生成java代码

    1.配置java环境变量,将java安装目录下bin文件夹下的xjc.exe配到classpath下 (一般有java环境变量就不用配置了) 2.进入xsd的文件夹下,cmd下执行 xjc -p 包路 ...

  2. cookie存值 后取值是string string字符串转对象

    实现方法 // 得到 对象 格式或 json 格式的一个字符串 var str = '{"name":"张根硕","age":"1 ...

  3. SLAM最近的工作

  4. 微信公众号支付开发当前URL未注册解决办法

    微信公众号支付,则需要现在微信支付商户后台,预先添加支付网址才可以.否则会出现“当前URL未注册”字样的报错. 方法/步骤 1. 报错实例如下,手机端微信调起微信支付框时弹出 2. 首先需要登录微信支 ...

  5. (转)面试必备技能:JDK动态代理给Spring事务埋下的坑!

    一.场景分析 最近做项目遇到了一个很奇怪的问题,大致的业务场景是这样的:我们首先设定两个事务,事务parent和事务child,在Controller里边同时调用这两个方法,示例代码如下: 1.场景A ...

  6. React.createClass 、React.createElement、Component

    react里面有几个需要区别开的函数 React.createClass .React.createElement.Component 首选看一下在浏览器的下面写法: <div id=" ...

  7. API 接口自动化测试框架

    转自: https://testerhome.com/topics/3455 前言 接口自动化逐渐成为各大公司投入产出最高的测试技术.但是如何在版本迅速迭代过程中提高接口自动化的测试效率,仍然是大部分 ...

  8. 数据分析与挖掘 - R语言:贝叶斯分类算法(案例二)

    接着案例一,我们再使用另一种方法实例一个案例 直接上代码: #!/usr/bin/Rscript library(plyr) library(reshape2) #1.根据训练集创建朴素贝叶斯分类器 ...

  9. np.percentile()

    np.percentile(a, q, axis=None, out=None, overwrite_input=False, interpolation='linear', keepdims=Fal ...

  10. IdentityServer4:Endpoint

    Endpoint的概念在IdentityServer里其实就是一些资源操作的url地址:如同Restful API里面的Endpoint是概念: 那么可以通过你自己的授权服务端得到相对应的地址与信息: ...