1. webdriver中常用属性

import time
from selenium import webdriver driver = webdriver.Firefox()
driver.maximize_window()
driver.implicitly_wait(30) driver.get("https://www.baidu.com") # 判断元素是否可见,返回结果为布尔值
res = driver.find_element_by_id("kw").is_displayed()
print(res) # 判断元素是否选中,返回结果为布尔值
res = driver.find_element_by_id("kw").is_selected()
print(res) # 判断元素是否可编辑,返回结果为布尔值
res = driver.find_element_by_id("kw").is_enabled()
print(res) # 在输入框中输入消息
driver.find_element_by_id("kw").send_keys("selenium")
time.sleep(2) # 提交表单(可看作模拟回车键)
driver.find_element_by_id("kw").submit()
time.sleep(2) # 清空输入框中输入的内容
driver.find_element_by_id("kw").clear()
time.sleep(2) # 得到元素的属性值
res = driver.find_element_by_id("kw").get_attribute('id')
print(res) # 得到元素的大小
res = driver.find_element_by_id("su").size
print(res) # 得到元素的文本
res = driver.find_element_by_link_text("贴吧").text
print(res) # 点击元素
driver.find_element_by_link_text("贴吧").click() time.sleep(2) driver.quit()

2. 浏览器页面操作

# -*- coding:utf-8 -*-
# Author: Aaron import time from selenium import webdriver driver = webdriver.Firefox() # 最大化浏览器窗口
driver.maximize_window()
# 隐式等待
driver.implicitly_wait(30) # 加载测试地址
driver.get("https://www.baidu.com/") # 获取当前使用的浏览器
res = driver.name
print(res) # 获取当前页面的标题
res = driver.title
print(res) # 获取当前页面的地址
res = driver.current_url
print(res) # 获取当前页面的代码
time.sleep(2)
res = driver.page_source
print(res) driver.get("https://cn.bing.com/") # 后退回上一个界面
time.sleep(2)
driver.back() # 前进到下一个页面
time.sleep(2)
driver.forward() # 刷新当前页面
time.sleep(2)
driver.refresh()
time.sleep(2) '''
多窗口
'''
driver.get("http://mail.sina.com.cn/")
# 获取当前页面的句柄
time.sleep(3)
now_handle = driver.current_window_handle
print(now_handle) driver.find_element_by_link_text('注册').click()
time.sleep(4) # 获取所有句柄
handles = driver.window_handles
print(handles)
for handle in handles:
if handle != now_handle:
driver.switch_to.window(handle)
time.sleep(2)
driver.find_element_by_name('email').send_keys('Aaron')
time.sleep(2)
# 关闭注册页面
# driver.close() # 切换为登录页面
driver.switch_to.window(now_handle)
driver.set_window_size(1080, 920)
time.sleep(2)
driver.find_element_by_id('freename').send_keys('Aaron')
time.sleep(2) # 关闭当前页面
driver.close()
time.sleep(2) # 退出驱动,并关闭所有页面
driver.quit()

3. 鼠标操作

'''
键盘操作步骤:
(1)导入ActionChains类
(2)定位需要操作的元素
(3)实例化对象
(4)调用ActionChains类的方法
''' import time
from selenium import webdriver
from selenium.webdriver.common.action_chains import ActionChains driver = webdriver.Firefox()
driver.maximize_window()
driver.implicitly_wait(30) driver.get("https://www.baidu.com/") # 鼠标悬停在"设置"上
element1 = driver.find_element_by_link_text("设置")
ActionChains(driver).move_to_element(element1).perform()
time.sleep(2) # 双击左键文字"有事搜一搜"
element2 = driver.find_element_by_css_selector("div > p[class='sub-title']")
ActionChains(driver).double_click(element2).perform()
time.sleep(2) # 单击右键
element3 = driver.find_element_by_id("su")
ActionChains(driver).context_click(element3).perform() time.sleep(5)
driver.quit()

4. 键盘操作

'''
键盘操作步骤:
(1)导入Keys类
(2)在send_keys()中使用Keys类的属性
''' import time
from selenium import webdriver
from selenium.webdriver.common.keys import Keys driver = webdriver.Firefox()
driver.maximize_window()
driver.implicitly_wait(30) driver.get('https://www.baidu.com/') element = driver.find_element_by_id("kw")
element.send_keys("selenium") # 模拟全选操作
element.send_keys(Keys.CONTROL, 'a')
time.sleep(2) # 模拟复制操作
element.send_keys(Keys.CONTROL, 'c')
time.sleep(2) # 模拟删除键
element.send_keys(Keys.BACKSPACE)
time.sleep(2) element.clear() # 模拟粘贴键
element.send_keys(Keys.CONTROL, 'v')
time.sleep(2) driver.quit()

5. 下拉框操作

'''
下拉框操作步骤:
(1)导入Select类
(2)定位select标签的元素
(3)实例化对象
(4)调用Select类的方法
''' import time
from selenium import webdriver
from selenium.webdriver.common.action_chains import ActionChains
from selenium.webdriver.support.select import Select driver = webdriver.Firefox()
driver.maximize_window()
driver.implicitly_wait(30) driver.get("https://www.baidu.com/") # 鼠标悬停在"设置"上
element1 = driver.find_element_by_link_text("设置")
ActionChains(driver).move_to_element(element1).perform()
time.sleep(2) # 点击"高级搜索",进入高级搜索界面
driver.find_element_by_link_text("高级搜索").click() # 定位"全部时间"下拉框的select标签
element = driver.find_element_by_css_selector('select[name="gpc"]')
# 实例化对象
slt = Select(element) # 通过索引方式定位下拉选项
slt.select_by_index(1)
time.sleep(2)
slt.select_by_index(4)
time.sleep(2) # 通过value属性定位
slt.select_by_value('stf')
time.sleep(2) # 通过文本属性定位
slt.select_by_visible_text("最近一天")
time.sleep(2)
slt.select_by_visible_text("最近一月")
time.sleep(2) driver.quit()

6. 弹出框操作

import time
from selenium import webdriver
from selenium.webdriver.common.action_chains import ActionChains
from selenium.webdriver.common.alert import Alert driver = webdriver.Firefox()
driver.maximize_window()
driver.implicitly_wait(30) driver.get("https://www.baidu.com/") ele = driver.find_element_by_link_text("设置")
ActionChains(driver).move_to_element(ele).perform()
time.sleep(2) driver.find_element_by_link_text("搜索设置").click()
time.sleep(2) driver.find_element_by_css_selector('.prefpanelgo').click()
time.sleep(2) # 输出弹出框内容
res = Alert(driver).text
print("弹框提示内容为:\n" + res)
# 接受弹出框
Alert(driver).accept() '''
另一种方法:
res = driver.switch_to_alert().text
print("弹框提示内容为:\n" + res)
driver.switch_to_alert().accept()
''' '''
对于弹出框的处理还有两种:
1.弹出框有两个按钮:“确认”和“取消”,这时用accept()和dismiss()来处理;
2.弹出框包含一个文本输入框时:用send_keys()来处理。
''' time.sleep(5)
driver.quit()

7. 窗口滚动条操作

'''
使用JavaScript脚本来辅助完成
用driver.execute_script(script)来实现
括号中的script为JavaScript脚本
''' import time
from selenium import webdriver driver = webdriver.Firefox()
driver.maximize_window()
driver.implicitly_wait(30) driver.get('https://www.baidu.com/') driver.find_element_by_css_selector('[id="kw"]').send_keys("selenium")
time.sleep(2)
driver.find_element_by_css_selector('[id="su"]').click()
time.sleep(2) # 垂直滚动条
# 滑动滚动条到窗口底部
bottom = 'window.scrollTo(0, 10000)'
driver.execute_script(bottom)
time.sleep(2) # 滑动滚动条到窗口顶部
top = 'window.scrollTo(0, 0)'
driver.execute_script(top)
time.sleep(2) # 设置窗口大小为500*500
driver.set_window_size(500, 500)
time.sleep(3) # 水平滚动条
# 滑动滚动条到窗口最右部
right = 'window.scrollTo(10000, 0)'
driver.execute_script(right)
time.sleep(2) # 滑动滚动条到窗口最左部
right = 'window.scrollTo(0, 0)'
driver.execute_script(right)
time.sleep(2) driver.quit()

8. 窗口截图操作

import time
from selenium import webdriver driver = webdriver.Firefox()
driver.maximize_window()
driver.implicitly_wait(30) driver.get('https://www.baidu.com/') time.sleep(2) # 截取浏览器窗口当前的界面保存为baidu_page1.png图片存放在路径E:\python下
driver.get_screenshot_as_file(r"E:\python\baidu_page1.png")
time.sleep(2) # 等价于get_screenshot_as_file()
driver.save_screenshot(r"E:\python\baidu_page2.png") driver.quit()

二、webdriver API的更多相关文章

  1. Webdriver API (二)

    (转载) 1.3 打开测试页面 对页面对测试,首先要打开被测试页面的地址(如:http://www.google.com),web driver 提供的get方法可以打开一个页面: // And no ...

  2. selenium初识(二)——之webdriver API

    配置完的环境之后,我们先来写一个小脚本: # __Author__:"Jim_xie" from selenium import webdriver from time impor ...

  3. Selenium2+Python:Webdriver API速记手册

    由于web自动化常常需要控制浏览器行为和操作页面元素,相关函数又比较多,于是再此记下一份Webdriver API查阅文档以备不时之需. 参考:虫师<Selenium2自动化测试实战>,和 ...

  4. python+selenium自动化软件测试(第2章):WebDriver API

    2.1 操作元素基本方法 前言前面已经把环境搭建好了,从这篇开始,正式学习selenium的webdriver框架.我们平常说的 selenium自动化,其实它并不是类似于QTP之类的有GUI界面的可 ...

  5. Selenium WebDriver Api 知识梳理

    之前一直没有系统的梳理WebDriver Api的相关知识,今天借此机会整理一下. 1.页面元素定位 1.1.8种常用定位方法 # id定位 driver.find_element_by_id() # ...

  6. 2.28 查看webdriver API

    2.28 查看webdriver API(带翻译) 前言    前面都是点点滴滴的介绍selenium的一些api使用方法,那么selenium的api到底有多少呢?本篇就教大家如何去查看seleni ...

  7. 转:python webdriver API 之操作测试对象

    一般来说,所有有趣的操作与页面交互都将通过 WebElement 接口,包括上一节中介绍的对象定位,以及本节中需要介绍的常对象操作.webdriver 中比较常用的操作元素的方法有下面几个: cle ...

  8. selenium2(WebDriver) API

    selenium2(WebDriver) API 作者:Glen.He出处:http://www.cnblogs.com/puresoul/  1.1  下载selenium2.0的包 官方downl ...

  9. webdriver API中文文档

    1.1   下载selenium2.0的lib包 http://code.google.com/p/selenium/downloads/list 官方UserGuide:http://seleniu ...

  10. python2.7运行selenium webdriver api报错Unable to find a matching set of capabilities

    在火狐浏览器33版本,python2.7运行selenium webdriver api报错:SessionNotCreatedException: Message: Unable to find a ...

随机推荐

  1. react+antd 点击分页为上次操作结果

    最近项目中在使用antd的分页组件时发生了第一次点击分页无变化,再次点击时数据为上一次的分页结果,代码如下: setPageIndex = (pagination)=> { const page ...

  2. Linux 正文处理命令及tar命令 利用vi编辑器创建和编辑正文文件

    要点回顾 1) 将用户信息数据库文件和组信息数据库文件纵向合并为一个文件/1.txt(覆盖) cp /etc/passwd . cat ./passwd >1.txt cp /etc/group ...

  3. STS Eclipse IDEA 指定启动JDK版本

    使用场景: 开发人员在自己的机器上可能装了多个版本的JDK,但是在环境变量中只能配置一个 JAVA_HOME ,so你的IDEA Eclipse 可能因为你在 JAVA_HOME 配置JDK1.8 以 ...

  4. 你看Http的 三次握手

    你看Http的 三次握手 按层次分,TCP位于传输层,而且TCP协议能够确认数据是否送达到对方,所以在客户端请求资源的时候,你得让俺知道咱俩关系是不是已经确定了啊,对不.这跟谈恋爱一样一样的,得先确定 ...

  5. ThinkPHP5.1接收post、get参数

    我们要先认识的是请求对象Request类 <?php//要用Request类 第一步就要引入他,才能在当前控制器上使用//知识点:use 与 namespace前面不可有空格等其他操作.name ...

  6. activiti工作流-概述

    1       应用场景 1.1 业务流程 采购系统完成了企业的日常采购管理,包括采购单管理.采购单审核.入库.结算等模块. 用户角色包括:员工.部门经理.总经理.财务. 基本业务流程如下: 1.2  ...

  7. Nutch2.3 编译

    $ antBuildfile: build.xmlTrying to override old definition of task javac ivy-probe-antlib: ivy-downl ...

  8. [转]关于/r与/n 以及 /r/n 的区别总结

    应该说还是区别的,\r就是回到行首,\n就是到下一行的,但是一般我们输出程序时,看不到明显的差别的 '\r'是回车,'\n'是换行,前者使光标到行首,后者使光标下移一格.通常用的Enter是两个加起来 ...

  9. 浅谈集合框架六——集合扩展:Arrays工具类、集合与数组相互转换方式;

    最近刚学完集合框架,想把自己的一些学习笔记与想法整理一下,所以本篇博客或许会有一些内容写的不严谨或者不正确,还请大神指出.初学者对于本篇博客只建议作为参考,欢迎留言共同学习. 之前有介绍集合框架的体系 ...

  10. Vue 双向数据绑定v-model

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...