selenium初识(二)——之webdriver API
配置完的环境之后,我们先来写一个小脚本:
# __Author__:"Jim_xie"
from selenium import webdriver
from time import sleep #打开浏览器
driver = webdriver.Chrome()
#以get方法打开指定浏览器
driver.get('http://music.163.com') #注意URL以HTTP开头
#等待3秒
sleep(3)
#关闭浏览器
driver.close()
注:建议在开始selenium+python学习之前,学习些python语言的基础知识,可以参考菜鸟教程
这是最基本的脚本,实现调用内置浏览器驱动,执行打开浏览器——打开指定URL——关闭浏览器的过程。
那么怎么去执行这个脚本呢?
有以下几个方法:
1.直接在常用的python IDE中直接执行,但是会出现关于驱动的报错:
这是驱动未配置到环境变量报错,但是有的时候会出现一些未知的报错,就像上面的一样,其实笔者已经将
相关的浏览器驱动都已经配置在环境变量中,仍然出现此报错。这个报错,如果各位有解决方案,请在评论中
告知。
2.虽然第一个方法会出错,但还是有其他方法执行的,首先提供第一种方法:通过cmd系统执行。
a.进入到该脚本目录下;
b.python small_script.py执行
3.另外一个方法,其实也是跟2比较类似:
a.打开python IDLE(可以从【开始】的安装程序中查找)
b.File——New File——Open File——然后从创建small_script.py的目录中选中它
c.Run——run module或者按F5
知晓了最基本的编写和执行之后,下面我们进入正题:webdriver API(官方API)
webdriver属于selenium体系中设计出来操作浏览器的一套API。
提点小建议:在Firefox和Chrome这两个浏览器中,xpath定义更准确地是Firefox。也就是说,可以使用Firefox定位
元素,自动化浏览器可以使用其他几种浏览器。
1.元素定位:
# __Author__:"Jim_xie" from selenium import webdriver
from selenium.webdriver.common.by import By #打开浏览器
driver = webdriver.Chrome()
#打开指定URL
driver.get('http://music.163.com')
#定位元素,指定URL下有唯一的id a
ele1 = driver.find_element_by_id('a')
ele01 = driver.find_element(By.ID,'a') #定位元素,指定URL下有唯一的name b
ele2 = driver.find_element_by_name('b')
ele02 = driver.find_element(By.NAME,'b') # 定位元素,指定URL下有唯一的class name c
ele3 = driver.find_element_by_class_name('c')
ele03 = driver.find_element(By.CLASS_NAME,'c') #定位元素,指定URL下有唯一的链接名称 d
ele4 = driver.find_element_by_link_text('d')
ele04 = driver.find_element(By.LINK_TEXT,'d') #定位元素,指定URL下有唯一的链接名称包含 e
ele5 = driver.find_element_by_partial_link_text('e')
ele05 = driver.find_element(By.PARTIAL_LINK_TEXT,'e') #定位元素,指定URL下有唯一的css selector f
ele6 = driver.find_element_by_css_selector('f')
ele06 = driver.find_element(By.CSS_SELECTOR,'f') #定位元素,指定URL下有唯一的xpath 可以通过F12选择页面上的元素然后在代码中点击复制,选择xpath复制即可
ele7 = driver.find_element_by_xpath('g')
ele07 = driver.find_element(By.XPATH,'g') #定位元素,指定URL下有唯一的tag_name h
ele8 = driver.find_element_by_tag_name('h')
ele08 = driver.find_element(By.TAG_NAME,'h') #定位元素组,指定URL下有多个tag name h
elem8 = driver.find_elements(By.TAG_NAME,'h')
elem08 = driver.find_elements_by_tag_name('h') '''其他元素组定位方式可以参考以上元素组定位方式'''
2. 控制浏览器
# __Author__:"Jim_xie" from selenium import webdriver
from selenium.webdriver.common.by import By #打开浏览器
driver = webdriver.Chrome()
#打开指定URL
driver.get('http://music.163.com') #获取浏览器窗口尺寸,以字典形成输出{'width': XXX,'height':XXX}
a = driver.get_window_size()
print(a) #控制浏览器最大化
driver.maximize_window() driver.get('http://www.cnr.cn') #控制浏览器返回上一页面
driver.back() #控制浏览器前进一页面
driver.forward() #控制浏览器刷新页面
driver.refresh() #获取浏览器位置,以字典的形式输出{'x‘:XX,'y':XX}
b = driver.get_window_position()
print(b) #关闭浏览器,只是关闭此标签页
driver.close() #关闭相关浏览器,彻底关浏览器,关闭所有标签页
driver.quit()
3.简单元素操作
# __Author__:"Jim_xie" from selenium import webdriver
from selenium.webdriver.common.by import By #打开浏览器
driver = webdriver.Firefox()
#打开指定URL
driver.get('http://music.163.com')
driver.implicitly_wait(3)
#定位登录按钮
login_button = driver.find_element_by_xpath('/html/body/div[1]/div[1]/div/div[1]/a')
#点击登录按钮
login_button.click() driver.find_element_by_xpath('/html/body/div[3]/div[2]/div/div/div[1]/div[2]/a').click() #定位用户名输入框
username = driver.find_element_by_id('p')
#清除用户名栏内容
username.clear()
#在用户名框内输入手机号
username.send_keys('')
#获取框的属性
a = username.get_attribute('type')
#获取框的大小 输出框的尺寸,字典格式{'height':XXX,'width':XXX}
a1 = username.size
#定位登录按钮
submit_botton = driver.find_element_by_xpath('/html/body/div[3]/div[2]/div/div[1]/div[5]/a')
#提取按钮尺寸
b = submit_botton.__sizeof__()
#获取按钮的文字内容
c = submit_botton.text
#判断元素是否展示,返回 True 或False
d = submit_botton.is_displayed()
print(a,a1,b,c,d) driver.quit()
4. 鼠标事件
需要导入模块:from selenium.webdriver.common.action_chains import ActionChains
# __Author__:"Jim_xie" from selenium import webdriver
from selenium.webdriver.common.by import By
from time import sleep
from selenium.webdriver.common.action_chains import ActionChains #打开浏览器
driver = webdriver.Firefox()
#打开指定URL
driver.get('http://www.jkslw.cn')
#隐性等待
driver.implicitly_wait(3)
#定位注册按钮
registry_button = driver.find_element_by_xpath('/html/body/div[3]/div[2]/div/p/a[2]')
#单击注册按钮
registry_button.click()
driver.implicitly_wait(3)
#定位logo元素
logo = driver.find_element_by_xpath('/html/body/div[1]/div/a')
#双击logo
ActionChains(driver).double_click(logo).perform()
sleep(2)
print(driver.title) driver.get('http://music.163.com')
ele = driver.find_element_by_xpath('/html/body/div[1]/div[1]/div/div[1]/a')
#右击元素
ActionChains(driver).context_click(ele).perform()
print(driver.title)
在执行过程中,发现右击的效果不明显,用得比较多的还是双击和点击
5.键盘事件
需要导入模块: from selenium.webdriver.common.keys import Keys
# __Author__:"Jim_xie" from selenium import webdriver
from selenium.webdriver.common.keys import Keys driver = webdriver.Firefox()
driver.get('http://www.baidu.com') ele = driver.find_element_by_xpath('//*[@id="kw"]')
#Keys.ENTER = 外接键盘按ENTER键
ele.send_keys('selenium',Keys.ENTER) print(driver.title)
from selenium.webdriver.common.keys import Keys
from selenium import webdriver ...
ele.send_keys(Keys.BACK_SPACE) #删除键
ele.send_keys(Keys.ALT) #ALT键
ele.send_keys(Keys.CONTROL,'a') #Ctrl +A
6.获取验证信息
# __Author__:"Jim_xie" from selenium import webdriver
from selenium.webdriver.common.keys import Keys driver = webdriver.Firefox()
driver.get('http://www.baidu.com') ele = driver.find_element_by_xpath('//*[@id="kw"]')
#Keys.ENTER = 外接键盘按ENTER键
ele.send_keys('selenium',Keys.ENTER) #页面标题
title = driver.title
print(title) driver.back()
#当前URL
url = driver.current_url
print(url) driver.quit()
7.设置元素等待
a.显性等待
# __Author__:"Jim_xie" from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.support.ui import WebDriverWait
from selenium.webdriver.support import expected_conditions as EC
from selenium.webdriver.common.keys import Keys
from time import sleep driver = webdriver.Firefox()
driver.get('http://www.baidu.com')
#WebDriver(driver,等待总时长,每N秒检查一次).直到某种状况为真
ele = WebDriverWait(driver,10,0.5).until(EC.presence_of_element_located((By.ID,'kw')))
ele.send_keys('你好',Keys.ENTER)
sleep(2)
print(driver.title)
driver.quit()
b.隐性等待,如果在定义的等待时间T内,接下来需要定位的元素或者页面没有出,就会抛出NoSuchElementException异常。
driver.implicitly_wait(等待时间T)
实际等待时间,小于等于T秒
c.time.sleep(等待时间F)
实际等待时间=等待时间F
8.Iframe多表单嵌套
遇到iframe多表单嵌套的时候切换表单页面操作:
driver.switch_to.iframe(#iframe id 或者 name) #切换到表单内
driver.switch_to.parent_iframe(#iframe id或name) #切换到上级表单
driver.switch_to.default_content() #跳出最外层页面
9.多窗口切换
driver.window_handles #获取所有窗口句柄
driver.current_window_handle #获取当前窗口句柄
driver.switch_to.window(窗口句柄) #切换到相应的窗口
10.警告框处理
JavaScript生成的警告框分为alert、confirm和prompt三种类型
python 2.7
driver.switch_to_alert().accept() #模拟点击确认,接受
driver.switch_to_alert().text #获取警告的文本内容
driver.swtitch_to_alert().dismiss() #解散现有警告框
driver.swtich_to_alert().send_keys(需要发送的文本) #向警告框中发送文本 python 3X
from selenium.webdriver.common.alter import Alert
Alter(driver).accept()
Alter(driver).text
Alter(driver).dismiss()
Alter(driver).senf_keys("需要发送的文本")
具体参考博客1
11.上传文件
如果是这种状况:
HTML代码中该上传位置为input标签的话可以使用实现上传目的
driver.find_element_by_xpath('XXXX').send_keys(文件绝对位置)
另外一种方法是使用Autolt辅助实现上传,因为比较复杂,不在这里赘述了
12.操作cookie
driver.get_cookies() #获取所有cookie
driver.get_cookie(name) #获取字典的key为name的cookie信息
driver.add_cookie(cookie_dict) #添加字典形式的cookie
driver.delete_cookie(name,optionString) #删除cookie信息 name是要删除的cookie名称,optionString是该cookie的选项
driver.delete_all-cookies() #删除所有的cookie
13.滚动条操作
js = "windows.scrollTo(左边距离,上边距离);" #别忘记";"
driver.excute_script(js) #实现浏览窗口的滚动条移动
14.截屏
driver.get_screenshot_as_file("保存的位置\文件名.扩展名") #截屏保存
基本的API操作就上面这14种,如有疑义欢迎评论区指导,谢谢!
selenium初识(二)——之webdriver API的更多相关文章
- <译>Selenium Python Bindings 6 - WebDriver API
本章涉及Selenium WebDriver的所有接口. Recommended Import Style 推荐的导入风格如下: from selenium import webdriver 然后,你 ...
- Selenium with Python 009 - WebDriver API
官方API文档:https://seleniumhq.github.io/selenium/docs/api/py/api.html 更多详情,最好的学习方式可以查阅官方API文档或直接阅读源码,本文 ...
- 二、webdriver API
目录 1. webdriver中常用属性 2. 浏览器页面操作 3. 鼠标操作 4. 键盘操作 5. 下拉框操作 1. webdriver中常用属性 import time from selenium ...
- python+selenium自动化软件测试(第2章):WebDriver API
2.1 操作元素基本方法 前言前面已经把环境搭建好了,从这篇开始,正式学习selenium的webdriver框架.我们平常说的 selenium自动化,其实它并不是类似于QTP之类的有GUI界面的可 ...
- Selenium WebDriver Api 知识梳理
之前一直没有系统的梳理WebDriver Api的相关知识,今天借此机会整理一下. 1.页面元素定位 1.1.8种常用定位方法 # id定位 driver.find_element_by_id() # ...
- Selenium自动化测试Python二:WebDriver基础
WebDriver基础 欢迎阅读WebDriver基础讲义.本篇讲义将会重点介绍Selenium WebDriver的环境搭建和基本使用方法. WebDriver环境搭建 Selenium WebDr ...
- selenium源码分析-webdriver(二)
最近比较空闲就仔细看了一下Selenium的源码,因为主要是使用WebDriver所以重点关注了一下WebDriver的工作原理.在前一篇blog里已经解释过了WebDriver与之前Selenium ...
- Webdriver API (二)
(转载) 1.3 打开测试页面 对页面对测试,首先要打开被测试页面的地址(如:http://www.google.com),web driver 提供的get方法可以打开一个页面: // And no ...
- [译]Selenium Python文档:七、WebDriver API接口
由于API文档格式不太适合cnblog博客,暂且翻译一部分,且暂未校对 注意:这不是官方文档,官方 API文档在这里. 本章包含Selenium WebDriver的所有接口 推荐import风格 本 ...
随机推荐
- selenium项目--读取测试用例
读取测试用例 一直我们都没有考虑过读取测试用例的事,我们现在这样设计测试用例有两个好的点,在执行方法时,打印测试用例,方便知道执行的内容是什么,在报告展示时,把测试用例的结果展示出来 实现方案:目前我 ...
- bzoj1801 [Ahoi2009]中国象棋
Description 在N行M列的棋盘上,放若干个炮可以是0个,使得没有任何一个炮可以攻击另一个炮. 请问有多少种放置方法,中国像棋中炮的行走方式大家应该很清楚吧. Input 一行包含两个整数N, ...
- MySQL 中while loop repeat 的基本用法
-- MySQL中的三中循环 while . loop .repeat 求 1-n 的和 -- 第一种 while 循环 -- 求 1-n 的和 /* while循环语法: while 条件 DO 循 ...
- JavaEE权限管理系统的搭建(三)--------springmvc和mabatis整合环境搭建
本节介绍如何环境的搭建和配置: 首先要在父工程引入jar包依赖: <!-- 通过属性定义指定jar的版本 --> <properties> <spring.version ...
- Nginx配置文件详细解释
转自:https://www.cnblogs.com/knowledgesea/p/5175711.html 序言 Nginx是lgor Sysoev为俄罗斯访问量第二的rambler.ru站点设计开 ...
- Raect Router 4 的使用 (1)
本文来自于官方文档,属于意译而非直译 基本组件 React Router 有三种类型的组件,分别是:react-router.react-router-dom.react-router-native ...
- 牛客小白月赛2 H 武 【Dijkstra】
链接:https://www.nowcoder.com/acm/contest/86/H来源:牛客网 题目描述 其次,Sεlιнα(Selina) 要进行体力比武竞赛. 在 Sεlιнα 所在的城市, ...
- Python代码结构——顺序、分支、循环
## 顺序结构 - 按照从上到下的顺序,一条语句一条语句的执行,是最基本的结构 ## 分支结构 if condition: statement statement ... elif condition ...
- Windows下如何安装composer
相对 来说并不难直接将此文件下载安装即可 1 https://getcomposer.org/Composer-Setup.exe 文件地址由官方提供 https://getcomposer.org/ ...
- hadoop的shuffle过程
1. shuffle: 洗牌.发牌——(核心机制:数据分区,排序,缓存): shuffle具体来说:就是将maptask输出的处理结果数据,分发给reducetask,并在分发的过程中,对数据按key ...