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(二)的更多相关文章

  1. Selenium2+python自动化27-查看selenium API

    前言 前面都是点点滴滴的介绍selenium的一些api使用方法,那么selenium的api到底有多少呢?本篇就叫大家如何去查看selenium api,不求人,无需伸手找人要,在自己电脑就有. p ...

  2. Robot Framework自动化测试(三)---Selenium API

    Robot  Framework  Selenium  API 说明: 此文档只是将最常用的UI 操作列出.更多方法请查找selenium 关键字库. 一.浏览器驱动 通过不同的浏览器执行脚本. Op ...

  3. Selenium2+python自动化-查看selenium API

    前面都是点点滴滴的介绍selenium的一些api使用方法,那么selenium的api到底有多少呢?本篇就叫大家如何去查看selenium api,不求人,无需伸手找人要,在自己电脑就有. pydo ...

  4. Robot Framework自动化测试三(selenium API)

    Robot  Framework  Selenium  API 说明: 此文档只是将最常用的UI 操作列出.更多方法请查找selenium2Library 关键字库. 一.浏览器驱动 通过不同的浏览器 ...

  5. Selenium2+python自动化27-查看selenium API【转载】

    前言 前面都是点点滴滴的介绍selenium的一些api使用方法,那么selenium的api到底有多少呢?本篇就叫大家如何去查看selenium api,不求人,无需伸手找人要,在自己电脑就有. p ...

  6. robotframework - selenium Api介绍

    一.介绍下selenium常用的api *** Settings ***Library SeleniumLibraryResource baidu业务.txtResource UI分层.txt *** ...

  7. Civil 3D API二次开发学习指南

    Civil 3D构建于AutoCAD 和 Map 3D之上,在学习Civil 3D API二次开发之前,您至少需要了解AutoCAD API的二次开发,你可以参考AutoCAD .NET API二次开 ...

  8. 用JSON-server模拟REST API(二) 动态数据

    用JSON-server模拟REST API(二) 动态数据 上一篇演示了如何安装并运行 json server , 在这里将使用第三方库让模拟的数据更加丰满和实用. 目录: 使用动态数据 为什么选择 ...

  9. Express4.x API (二):Request (译)

    写在前面 最近学习express想要系统的过一遍API,www.expressjs.com是express英文官网(进入www.epxressjs.com.cn发现也是只有前几句话是中文呀~~),所以 ...

  10. python+selenium十:基于原生selenium的二次封装

    from selenium import webdriverfrom selenium.webdriver.support.wait import WebDriverWaitfrom selenium ...

随机推荐

  1. 40个Java多线程问题总结【转】

    1.多线程有什么用? 一个可能在很多人看来很扯淡的一个问题:我会用多线程就好了,还管它有什么用?在我看来,这个回答更扯淡.所谓”知其然知其所以然”,”会用”只是”知其然”,”为什么用”才是”知其所以然 ...

  2. [C#] 等待启动的进程执行完毕

    有能有时候我们启动了一个进程,必须等到此进程执行完毕,或是,一段时间, 关闭进程后再继续往下走. Example sample1 等待应用程序执行完毕 //等待应用程序执行完毕 private voi ...

  3. 「小程序JAVA实战」微信小程序工程结构了解(五)

    转自:https://idig8.com/2018/08/09/xiaochengxu-chuji-05/ 微信小程序工程结构 audio,button,canvas,checkbox 都是由4个文件 ...

  4. 每天一个Linux命令 - 【find】

    命令:find 用途:查找文件并执行指令的操作 [语法]:find [路径] [选项] [参数] [功能介绍]:find命令在指定的目录下查找文件.find命令还能够对查找到的文件执行的指定的操作,通 ...

  5. 生成ssl脚本文件

    read -p "Enter your domain [www.example.com]: " DOMAIN echo "Create server key...&quo ...

  6. phpmailer邮件类

    <?php/** * 邮件类 * Enter description here ... * @author df * Mail::getMail()->sendMail(); * */cl ...

  7. 因采用 Flask 原生 WSGI 出现 "Broken pipe" 报错的故障处理

    :first-child { margin-top: 0; } blockquote > :last-child { margin-bottom: 0; } img { border: 0; m ...

  8. springBoot集成 quartz动态定时任务

    项目中需要用到定时任务,考虑了下java方面定时任务无非就三种: 用Java自带的timer类.稍微看了一下,可以实现大部分的指定频率的任务的调度(timer.schedule()),也可以实现关闭和 ...

  9. TOP命令 详解CPU 查看多个核心的利用率按1

    top命令是linux下常用的工具,可以查看各个进程的CPU使用情况.先看一个实例: 这是Ramnode双核VPS的top显示结果: 左上角可以看到CPU的使用率是11.3%,但是看下面的进程,plu ...

  10. solr开发之基本操作

    package zr.com.util; import java.io.IOException; import java.util.List; import java.util.Map; import ...