元素定位

#coding=utf-8

from selenium import webdriver
from selenium.webdriver.firefox.firefox_binary import FirefoxBinary
import time
binary = FirefoxBinary('/Applications/FirefoxDeveloperEdition.app/Contents/MacOS/firefox-bin')
driver = webdriver.Firefox(firefox_binary=binary) driver.get('http://www.baidu.com')
size = driver.find_element_by_id('kw').size
print(size) text = driver.find_element_by_id('cp').text
print(text) size1 = driver.find_element_by_id('kw').get_attribute('type')
print(size1) size2 = driver.find_element_by_id('kw').is_displayed()
print(size2) driver.find_element_by_id('kw').clear()
driver.find_element_by_id('kw').send_keys('selenium')
driver.find_element_by_id('su').click() time.sleep(2)
driver.get('http://news.baidu.com') time.sleep(2)
driver.back() time.sleep(2)
driver.forward() time.sleep(2)
driver.refresh()

鼠标键盘操作

#coding=utf-8
from selenium import webdriver
from selenium.webdriver.firefox.firefox_binary import FirefoxBinary
from selenium.webdriver.common.action_chains import ActionChains
from selenium.webdriver.common.keys import Keys import time
binary = FirefoxBinary('/Applications/FirefoxDeveloperEdition.app/Contents/MacOS/firefox-bin')
driver = webdriver.Firefox(firefox_binary=binary) driver.get('http://www.baidu.com') right_click = driver.find_element_by_id("listHolder")
# 右键
ActionChains(driver).context_click(right_click).perform() # 鼠标悬停
above = driver.find_element_by_name("tj_settingicon")
ActionChains(driver).move_to_element(above).perform() #双击
double_click = driver.find_element_by_id('xx')
ActionChains(driver).double_click(double_click).perform() # 拖动
drag_start = driver.find_element_by_id('xx')
drag_end = driver.find_element_by_id('cc')
ActionChains(driver).drag_and_drop(drag_start,drag_end).perform() #输入框输入内容
driver.find_element_by_id('kw').send_keys('hha') #删除多输入的内容
driver.find_element_by_id('kw').send_keys(Keys.BACK_SPACE) #输入空格
driver.find_element_by_id('kw').send_keys(Keys.SPACE) # ctrl+a全选
driver.find_element_by_id('kw').send_keys(Keys.CONTROL,'a') #回车
driver.find_element_by_id('kw').send_keys(Keys.ENTER)

显式/隐式等待

#coding=utf-8
from selenium import webdriver
from selenium.webdriver.firefox.firefox_binary import FirefoxBinary
from selenium.webdriver.common.by import By
from selenium.webdriver.support.ui import WebDriverWait
from selenium.webdriver.support import expected_conditions as EC binary = FirefoxBinary('/Applications/FirefoxDeveloperEdition.app/Contents/MacOS/firefox-bin')
driver = webdriver.Firefox(firefox_binary=binary) driver.get('http://www.baidu.com') #显式等待
element = WebDriverWait(driver,5,0.5).until(EC.presence_of_all_elements_located((By.ID,'kw')))
element.send_keys('ss') #隐式等待 from selenium.common.exceptions import NoSuchElementException
driver.implicitly_wait(10)
driver.get('http://www.baidu.com')
try:
driver.find_element_by_id('kw').send_keys('ss')
except NoSuchElementException as e:
print(e)

窗口/frame切换

#coding=utf-8
from selenium import webdriver
from selenium.webdriver.firefox.firefox_binary import FirefoxBinary
binary = FirefoxBinary('/Applications/FirefoxDeveloperEdition.app/Contents/MacOS/firefox-bin')
driver = webdriver.Firefox(firefox_binary=binary) driver.get('http://www.baidu.com') #iframe切换id或name,否则用XPATH定位
driver.switch_to.frame("if") #返回之前页面
driver.switch_to.parent_frame() # 多窗口切换 #获得当前窗口句柄
search_windows=driver.current_window_handle driver.find_element_by_link_text('登录').click()
driver.find_element_by_link_text('立即注册').click() #获取当前所有打开的窗口句柄
all_handles = driver.window_handles #进入注册窗口
for handle in all_handles:
if handle != search_windows:
driver.switch_to.window(handle)
print('注册。。。')
# 填写信息send_keys #回到之前窗口
for handle in all_handles:
if handle ==search_windows:
driver.switch_to.window(handle)
print('搜索。。。')

警告框处理

from selenium import webdriver
from time import sleep driver = webdriver.Chrome()
driver.get("https://www.baidu.com") driver.find_element_by_link_text("设置").click()
driver.find_element_by_class_name("setpref").click()
sleep(2) # 保存设置
driver.find_element_by_class_name("prefpanelgo").click()
sleep(2) # 接受警告框
driver.switch_to.alert().accept() driver.quit()

文件下载

from selenium import webdriver
import os # download.default_directory 指定文件下载路径。
# profile.default_content_settings.popups 设置0,禁止下载时弹出窗口。 options = webdriver.ChromeOptions()
prefs = {'profile.default_content_settings.popups': 0,
'download.default_directory': os.getcwd()
}
options.add_experimental_option('prefs', prefs) driver = webdriver.Chrome(chrome_options=options)
driver.get("http://pypi.Python.org/pypi/selenium")
driver.find_element_by_partial_link_text("selenium-3.0.2.tar.gz").click()

文件上传

from selenium import webdriver
import os, time driver = webdriver.Chrome()
file_path = 'file:///' + os.path.abspath('./webdriver_api/web_page/upfile.html')
driver.get(file_path) time.sleep(2)
# 定位上传按钮,添加本地文件
driver.find_element_by_name("file").send_keys(os.path.abspath('./webdriver_api/web_page/upload_file.txt'))
time.sleep(5)
driver.quit()

操作cookie

from selenium import webdriver
driver = webdriver.Chrome() '''
* get_cookies() 获得所有 cookie 信息。
* get_cookie(name) 返回字典的 key 为“ name”的 cookie 信息。
* add_cookie(cookie_dict) 添加 cookie。“ cookie_dict”指字典对象,必须有name和value 值。
* delete_cookie(name,optionsString) 删除 cookie 信息。“name”是要删除的 cookie 的名称,
“optionsString”是该 cookie 的选项,目前支持的选项包括“路径”,“域”。
* delete_all_cookies() 删除所有 cookie 信息。
''' driver.get("https://www.baidu.com") # 向 cookie 的 name 和 value 中添加会话信息
driver.add_cookie({'name': 'key-aaaaaaa', 'value': 'value-bbbbbb'}) # 遍历 cookies 中的 name 和 value 信息并打印,当然还有上面添加的信息
for cookie in driver.get_cookies():
print("%s -> %s" % (cookie['name'], cookie['value'])) driver.quit()

调用javascript

from selenium import webdriver
from time import sleep #execute_script() 调用JavaScript操作Web。 driver=webdriver.Chrome()
driver.get("https://www.baidu.com") driver.set_window_size(600, 600)
driver.find_element_by_id("kw").send_keys("selenium")
driver.find_element_by_id("su").click()
sleep(2) # 通过 javascript 设置浏览器窗口的滚动条位置
js="window.scrollTo(100,450);"
driver.execute_script(js)
sleep(3)
driver.quit()

窗口截图

from selenium import webdriver
from time import sleep
import os # get_screenshot_as_file() 截取窗口图片。
driver = webdriver.Chrome()
driver.get('https://www.baidu.com')
driver.find_element_by_id('kw').send_keys('selenium')
driver.find_element_by_id('su').click()
sleep(2) # 截取当前窗口,并指定截图图片的保存位置
driver.get_screenshot_as_file(os.path.abspath('./webdriver_api/web_page/baidu_page.jpg'))
driver.quit()

视频播放处理

from selenium import webdriver
from time import sleep driver = webdriver.Chrome()
driver.get("http://videojs.com/")
video = driver.find_element_by_id("home_video") # 返回播放文件地址
url = driver.execute_script("return arguments[0].currentSrc;", video)
print(url) # 播放视频
print("start")
driver.execute_script("return arguments[0].play()", video) # 播放 15 秒钟
sleep(15) # 暂停视频
print("stop")
driver.execute_script("arguments[0].pause()", video)
driver.quit()

下拉框选择

from selenium import webdriver
from selenium.webdriver.support.select import Select
import os driver = webdriver.Chrome()
file_path = 'file:///' + os.path.abspath('./webdriver_api/web_page/select_tag.html')
driver.get(file_path) sel = driver.find_element_by_xpath("//select[@id='status']")
Select(sel).select_by_value('') #未审核
Select(sel).select_by_value('') #初审通过
Select(sel).select_by_value('') #复审通过
Select(sel).select_by_value('') #审核不通过

selenium webdriver API的更多相关文章

  1. 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 ...

  2. Selenium WebDriver Api 知识梳理

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

  3. Python + Selenium WebDriver Api 知识回顾

    一直再用 Selenium WebDriver 但是用的都比较零散,也没有做过总结,今天借此机会,整理一下,方便大家使用时查阅 webDriver  的属性 ['CONTEXT_CHROME', 'C ...

  4. Selenium - Webdriver API /ActionChains API

    一.控制浏览器 1.1 控制浏览器窗口大小 # 获取当前浏览器的大小  driver.get_window_size() # 通过像素设置浏览器的大小  driver.set_window_size( ...

  5. selenium webdriver API详解(三)

    本系列主要讲解webdriver常用的API使用方法(注意:使用前请确认环境是否安装成功,浏览器驱动是否与谷歌浏览器版本对应) 一:获取页面元素的文本内容:text 例:获取我的博客名字文本内容 代码 ...

  6. selenium webdriver API详解(二)

    本系列主要讲解webdriver常用的API使用方法(注意:使用前请确认环境是否安装成功,浏览器驱动是否与谷歌浏览器版本对应) 一:获取当前页面的title(一般获取title用于断言) from s ...

  7. selenium webdriver API详解(一)

    本系列主要讲解webdriver常用的API使用方法(注意:使用前请确认环境是否安装成功,浏览器驱动是否与谷歌浏览器版本对应) 一:打开某个网址:get() from selenium import ...

  8. Python+Selenium WebDriver API:浏览器及元素的常用函数及变量整理总结

    由于网页自动化要操作浏览器以及浏览器页面元素,这里笔者就将浏览器及页面元素常用的函数及变量整理总结一下,以供读者在编写网页自动化测试时查阅. from selenium import webdrive ...

  9. Python+Selenium webdriver Api

    # -*- coding: utf-8 -*- from selenium import webdriver browser = webdriver.Firefox() #browser.set_wi ...

随机推荐

  1. 使用myeclipse出现中文乱码的情况以及解决办法

    一:在jsp页面使用中文在浏览器中显示的时候出现乱码,解决问题的办法: 1)直接在<mete>标签中修改charset属性为"utf-8"或者为"gb2312 ...

  2. SQL Server 扩展事件

    SQL Server 扩展事件(Extended Event)是用于服务器的常规事件处理系统,是追踪SQL Server系统运行状态的神器,同时也是一个日志记录工具,扩展事件完全可以取代SQL追踪(S ...

  3. nuxt项目踩坑

    1.window or document is not undefined // .vue 页面 if (process.browser) { var Distpicker = require('v- ...

  4. 洛谷P1501 [国家集训队]Tree II(LCT,Splay)

    洛谷题目传送门 关于LCT的其它问题可以参考一下我的LCT总结 一道LCT很好的练习放懒标记技巧的题目. 一开始看到又做加法又做乘法的时候我是有点mengbi的. 然后我想起了模板线段树2...... ...

  5. 8Manage:物流CRM,深度挖掘快递企业下一站蓝海!

    [导读]网购的普及加快了快递物流服务在中国的发展,而物流行业也开始展露出自身巨大的发展潜力和进步空间.其中,作为物流行业根本核心的物流客户关系管理开始引起了管理者的注意,如何升级用户物流服务体验,把握 ...

  6. 同一台电脑同时装Oracle客户端和服务端

    1.如果之前安装过Oracle,Win+R输入Services.msc,关掉以Oracle开头的服务(卸载Oracle服务端和客户端步骤一样,见另外一篇帖子) 2.Win+R输入regedit打开注册 ...

  7. unity(c# ioc框架) 使用总结

    这里的unity指的是完成依赖注入的unity而不是游戏引擎. 原本项目完成依赖注入用的是spring.net,但是spring.net已经很久没人维护了,所以微软官方推出的Unity成为了替代spr ...

  8. 负载均衡,会话保持,session同步(转)

    转自:http://bbs.linuxtone.org/thread-18212-1-1.html 一,什么负载均衡一个新网站是不要做负载均衡的,因为访问量不大,流量也不大,所以没有必要搞这些东西.但 ...

  9. 使用MBROSTool 工具制作本地硬盘F3救急模式的方法总结

    前面写了一篇使用MBROSTool 工具制作本地硬盘多启动盘的方法总结.里面就是可以把一些系统安装到硬盘上面方便使用,比如安装PE到硬盘,不过启动的时候会先进入多UDm菜单,然后选择[启动本地系统]后 ...

  10. Selenium学习资源和网站

    用于收集常用的网站和学习资源: 文章: Selenium私房菜系列--总章 WEB 自动化测试工具 Selenium 简介及其应用 Selenium教程 和我一起学 Selenium WebDrive ...