Selenium API(二)
1.定位一组元素
WebDriver提供了8种定位一组元素的方法。
driver.find_elements_by_css_selector()
driver.find_elements_by_tag_name()
driver.find_elements_by_class_name()
driver.find_elements_by_xpath()
driver.find_elements_by_id()
driver.find_elements_by_link_text()
driver.find_elements_by_name()
driver.find_elements_by_partial_link_text()
# -*- coding:utf- -*-
from selenium import webdriver
import os
import time
driver = webdriver.Firefox()
file_path = "file:///" + os.path.abspath('testcheck.html')
driver.get(file_path)
inputs = driver.find_elements_by_tag_name("input")
for input in inputs:
if input.get_attribute("type") == "checkbox":
input.click()
time.sleep()
driver.quit()
2.多表单切换
WebDriver只能在一个页面上对元素进行识别和定位,对于frame/iframe表单内嵌页面上的元素无法直接定位,因此WebDriver提供了方法将当前定位的主体切换为frame/iframe表单的内嵌页面中。
switch_to.frame(),默认可以直接取表单的id或者name属性,如果iframe没有可用的id和name属性,可以通过下面的方式定位:
...
# 先通过css定位到iframe
iframe = driver.find_element_by_css_selector("[class='iframe']")
# 再将定位对象传给switch_to.frame()方法
driver.switch_to.frame(iframe)
...
driver.switch_to.parent_frame()
说明:当完成了当前iframe操作后,可以通过driver.switch_to.parent_frame()跳出当前一级表单,该方法默认对应于离他最近的switch_to.frame()方法,此外,在进入多级表单的情况下,还可以通过switch_to.default_content()跳会到最外层的页面。
3.多页面切换
WebDriver提供了switch_to.window()方法实现在不同的窗口之间切换。
# -*- coding:utf- -*-
from selenium import webdriver
import os
import time
driver = webdriver.Firefox()
driver.implicitly_wait()
driver.get("http://www.baidu.com")
# 获得百度搜索窗口句柄
search_handle = driver.current_window_handle driver.find_element_by_link_text("登录").click()
driver.find_element_by_link_text("立即注册").click()
time.sleep()
# 获取当前所有打开的窗口的句柄
all_handles = driver.window_handles
for handle in all_handles:
if handle != search_handle:
# 如果句柄不为搜索窗口的句柄,则切换到注册页面
driver.switch_to.window(handle)
print("now register window!")
time.sleep() for handle in all_handles:
if handle == search_handle:
driver.switch_to.window(handle)
driver.find_element_by_id("TANGRAM__PSP_4__closeBtn").click()
driver.find_element_by_id("kw").send_keys("selenium")
driver.find_element_by_id("su").click()
time.sleep() driver.quit()
4.警告框处理
在WebDriver中通过使用switch_to_alert()方法定位到alert/confirm/prompt,然后使用text/accept/dismiss/send_keys等方法进行操作。
text:返回alert/confirm/prompt中的文字信息。
accept():接受现有警告框。
dismiss():解散现有警告框。
send_keys(keysToSend):发送文本到警告框。keysToSend:将文本发送至警告框。
5.send_keys()实现文件上传
# 定位上传按钮,然后添加本地文件
driver.find_element_by_name("file").send_keys("f:\\upload_file.txt")
如果想要实现文件上传,只需要找到上传的input标签,基本伤可以同send_keys()方法将文件上传。
6.文件下载
# -*- coding:utf- -*-
from selenium import webdriver
import os
import time
firefox_profile = webdriver.FirefoxProfile()
# 设置为0代表下载到浏览器默认下载路径,设置为2则表示可以保存到执行目录中
firefox_profile.set_preference("browser.download.folderList", )
# 是否显示开始,True为显示,False为不显示
firefox_profile.set_preference("browser.download.manager.showWhenStarting", False)
# 执行下载的目录,os.getcwd()返回当前目录
firefox_profile.set_preference("browser.download.dir", os.getcwd())
# 设置下载文件的类型
firefox_profile.set_preference("browser.helperApps.neverAsk.saveToDisk", "application/octet-stream") driver = webdriver.Firefox(firefox_profile=firefox_profile)
driver.get("xxx")
driver.find_element_by_name("xxx").click()
driver.quit()
7.操作Cookie
WebDriver提供了操作Cookie的方法,可以读取,添加和删除cookie信息:
- get_cookies():获得所有cookie信息。
- get_cookie():返回字典的key为“name”的cookie信息。
- add_cookie(cookie_dict):添加cookie。cookie_dict为字典对象,必须有name和value。
- delete_cookie():删除cookie信息,需要指定name,即要删除的cookie的名称。
- delete_all_cookies():删除所有的cookie信息。
8.执行JavaScript
WebDriver提供了execute_script()方法来执行JavaScript代码。
# -*- coding:utf- -*-
from selenium import webdriver
import os
import time driver = webdriver.Firefox()
# 设置浏览器窗口大小
driver.set_window_size(, )
driver.get("http://www.baidu.com")
driver.find_element_by_id("kw").send_keys("selenium")
driver.find_element_by_id("su").click()
time.sleep()
js = "window.scrollTo(100, 400)"
# 执行js脚本,设置窗口到滚动条的位置
driver.execute_script(js)
time.sleep()
driver.quit()
9.窗口截图
WebDriver提供了get_screenshot_as_file()来截取当前窗口。
# -*- coding:utf- -*-
from selenium import webdriver
import os
import time driver = webdriver.Firefox() driver.get("http://www.baidu.com")
driver.find_element_by_id("kw").send_keys("selenium")
driver.find_element_by_id("su").click()
time.sleep()
# 截取当前窗口,并制定截图保存的位置
driver.get_screenshot_as_file("d:\\test.jpg")
driver.quit()
10.关闭浏览器窗口
WebDriver提供了quit()方法,其含义为退出相关的驱动程序和关闭所有窗口,另外提供了close()方法,用来关闭某一个窗口。
Selenium API(二)的更多相关文章
- Selenium2+python自动化27-查看selenium API
前言 前面都是点点滴滴的介绍selenium的一些api使用方法,那么selenium的api到底有多少呢?本篇就叫大家如何去查看selenium api,不求人,无需伸手找人要,在自己电脑就有. p ...
- Robot Framework自动化测试(三)---Selenium API
Robot Framework Selenium API 说明: 此文档只是将最常用的UI 操作列出.更多方法请查找selenium 关键字库. 一.浏览器驱动 通过不同的浏览器执行脚本. Op ...
- Selenium2+python自动化-查看selenium API
前面都是点点滴滴的介绍selenium的一些api使用方法,那么selenium的api到底有多少呢?本篇就叫大家如何去查看selenium api,不求人,无需伸手找人要,在自己电脑就有. pydo ...
- Robot Framework自动化测试三(selenium API)
Robot Framework Selenium API 说明: 此文档只是将最常用的UI 操作列出.更多方法请查找selenium2Library 关键字库. 一.浏览器驱动 通过不同的浏览器 ...
- Selenium2+python自动化27-查看selenium API【转载】
前言 前面都是点点滴滴的介绍selenium的一些api使用方法,那么selenium的api到底有多少呢?本篇就叫大家如何去查看selenium api,不求人,无需伸手找人要,在自己电脑就有. p ...
- robotframework - selenium Api介绍
一.介绍下selenium常用的api *** Settings ***Library SeleniumLibraryResource baidu业务.txtResource UI分层.txt *** ...
- Civil 3D API二次开发学习指南
Civil 3D构建于AutoCAD 和 Map 3D之上,在学习Civil 3D API二次开发之前,您至少需要了解AutoCAD API的二次开发,你可以参考AutoCAD .NET API二次开 ...
- 用JSON-server模拟REST API(二) 动态数据
用JSON-server模拟REST API(二) 动态数据 上一篇演示了如何安装并运行 json server , 在这里将使用第三方库让模拟的数据更加丰满和实用. 目录: 使用动态数据 为什么选择 ...
- Express4.x API (二):Request (译)
写在前面 最近学习express想要系统的过一遍API,www.expressjs.com是express英文官网(进入www.epxressjs.com.cn发现也是只有前几句话是中文呀~~),所以 ...
- python+selenium十:基于原生selenium的二次封装
from selenium import webdriverfrom selenium.webdriver.support.wait import WebDriverWaitfrom selenium ...
随机推荐
- mysql ,show slave status详解
===想确认sql_thread线程是否应用完了io_thread接收到的了relay log,看 Master_Log_File=Relay_Master_Log_File , Read_Maste ...
- 微信开发准备(四)--nat123内网地址公网映射实现
转自:http://www.cuiyongzhi.com/post/37.html 在前面几篇中我们一直说的开发准备工作主要是基于开发框架上的,这里我们说的就逐渐接近开发过程中的实体操作了,如果你之前 ...
- peerconnection_client分析笔记
Windows版本的peerconnection_client demo是一个win32程序,入口函数为main.cc里面的wWinMain,程序整体流程就从这个入口函数下手开始分析. 1.peer ...
- 性能调试工具——oprofile
oprofile利用cpu硬件层面提供的性能计数器(performance counter),通过计数采样,帮助我们从进程.函数.代码层面找出占用cpu的"罪魁祸首". 常用命令 ...
- json_encode和json_decode和isset和array_key_exists
1.json_decode() json_decode — 对 JSON 格式的字符串进行编码 说明 mixed json_decode ( string $json [, bool ...
- Windows:condition_variable 两个例子
题目:子线程循环 10 次,接着主线程循环 100 次,接着又回到子线程循环 10 次,接着再回到主线程又循环 100 次,如此循环50次,试写出代码.注意:一定是子线程先执行,主线程再执行. #in ...
- poj1722 SUBTRACT
应该是基础的dp练手题 线性dp最主要的就是关于阶段的划分,这个题中我没想到的一点就是开状态的时候使用了前i个数能合成的数来记录 我自己的想法就是类似于区间dp这样的记录方法,这种方法确实开了很多冗余 ...
- bootstrap列排序
<!DOCTYPE html> <html> <head> <title>Bootstrap 实例 - 列排序</title> <li ...
- URAL 1356. Something Easier(哥德巴赫猜想)
题目链接 题意 : 给你一个数n,让你找出几个素数,使其相加为n,输出这些素数. 思路 : 哥德巴赫猜想 : 任何一个大于 6的偶数都可以表示成两个素数之和. 任何一个大于9的奇数都可以表示成三个素数 ...
- (转)QueryBuilder : 打造优雅的Linq To SQL动态查询
原文地址:http://www.cnblogs.com/coolcode/archive/2009/09/28/IQueryBuilder.html 首先我们来看看日常比较典型的一种查询Form 这个 ...