【selenium2】【selenium基础语法】
#栗子 设置浏览器窗口大小
driver.set_window_size(480,800)
#栗子 设置浏览器大小为最大
maximize_window()
控制浏览器前进、后退
#栗子
from selenium import webdriver
driver = webdriver.Chrome()
#访问百度首页
first_url = 'http://www.baidu.com'
print('now access %s' % (first_url))
driver.get(first_url)
#访问新闻首页
second_url = 'http://news.baidu.com'
print('now access %s ' % (second_url))
driver.get(second_url)
#返回到百度首页
print('back to %s' % first_url)
driver.back()
#前进到新闻也
print('forward to %s' % (second_url))
driver.forward()
#栗子
from selenium import webdriver
from selenium.webdriver.common.by import By
driver = webdriver.Chrome()
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)
#返回元素的属性值
attr = driver.find_element(By.ID,'kw').get_attribute('type')
print(attr)
#返回元素的结果是否可以看见
result = driver.find_element(By.ID,'kw').is_displayed()
print(result)
#栗子:鼠标事件
from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.common.action_chains import ActionChains
driver = webdriver.Chrome()
driver.get('http://www.baidu.com')
#定位到要右击的元素
right_click = driver.find_element(By.ID,'kw')
#对定位的元素执行鼠标右键的操作
ActionChains(driver).context_click(right_click).perform()
#定位到要悬停的元素
above = driver.find_element(By.LINK_TEXT,'设置')
#对定位到的元素执行悬停操作
ActionChains(driver).move_to_element(above).perform()
#定位到要双击的元素
double_click = driver.find_element(By.XPATH,"//div[@id='lg']")
#对定位到的元素执行双击操作
ActionChains(driver).double_click(double_click).perform()
#鼠标推放元素:这个我试用在百度首页,貌似不好用,其他场景没试过
#定位元素的元位置
element = driver.find_element(By.CSS_SELECTOR,"div[class='qrcode-img']")
#定位元素要移动到的目标位置
target = driver.find_element(By.LINK_TEXT,'新闻')
#执行元素的拖放操作
ActionChains(driver).drag_and_drop(element,target).perform()
#栗子 键盘操作
from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.common.keys import Keys
driver = webdriver.Chrome()
driver.get('http://www.baidu.com')
#输入框输入内容
driver.find_element(By.ID,'kw').send_keys('selenium22')
#删除多输入的一个22
driver.find_element(By.ID,'kw').send_keys(Keys.BACK_SPACE)
#输入空格键 + ‘教程’
driver.find_element(By.ID,'kw').send_keys(Keys.SPACE)
driver.find_element(By.ID,'kw').send_keys(u'教程')
#ctrl+a 全选输入框内容
driver.find_element(By.ID,'kw').send_keys(Keys.CONTROL,'a')
#ctrl+x 剪切输入框内容
driver.find_element(By.ID,'kw').send_keys(Keys.CONTROL,'x')
#ctrl+v 黏贴内容到输入框
driver.find_element(By.ID,'kw').send_keys(Keys.CONTROL,'v')
#通过回车键来代替点击操作
driver.find_element(By.ID,'kw').send_keys(Keys.ENTER)
#栗子 获得验证信息
from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.common.keys import Keys
driver = webdriver.Chrome()
driver.get('http://www.baidu.com')
title = driver.title
print(title)
now_url = driver.current_url
print(now_url)
driver.find_element(By.ID,'kw').send_keys('selenium2')
driver.find_element(By.ID,'su').click()
#再次打印当前页面URL
print(driver.current_url)
#再次打印当前页面title
print(driver.title)
'''
百度一下,你就知道
https://www.baidu.com/
https://www.baidu.com/s?ie=utf-8&f=8&rsv_bp=0&rsv_idx=1&tn=baidu&wd=selenium2&rsv_pq=b27adbf80000663c&rsv_t=a70btEBJGoDKAin6mRi8AzpsW0eRkwBIOaViQAzDNBiK0EL5CLmW2Z1Onjo&rqlang=cn&rsv_enter=0&rsv_sug3=9&rsv_sug1=1&rsv_sug7=100&inputT=496&rsv_sug4=496
百度一下,你就知道
'''
# 栗子 显式等待
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
driver = webdriver.Chrome()
driver.get('http://www.baidu.com')
element = WebDriverWait(driver,5,0.5).until(EC.presence_of_element_located((By.ID,'kw')))
element.send_keys('selenium22')
【备注】
WebDriverWait()
它是由 webdirver 提供的等待方法。在设置时间内,默认每隔一段时间检测一次当前页面元素是否存
在,如果超过设置时间检测不到则抛出异常。具体格式如下:
WebDriverWait(driver, timeout, poll_frequency=0.5, ignored_exceptions=None)
driver - WebDriver 的驱动程序(Ie, Firefox,Chrome 等)
timeout - 最长超时时间,默认以秒为单位
poll_frequency - 休眠时间的间隔(步长)时间,默认为 0.5 秒
ignored_exceptions - 超时后的异常信息,默认情况下抛 NoSuchElementException 异常。
until()
WebDriverWait()一般由 until()(或 until_not())方法配合使用,下面是 until()和 until_not()方法的说明。
until(method, message=’ ’)
调用该方法提供的驱动程序作为一个参数,直到返回值为 Ture。
until_not(method, message=’ ’)
调用该方法提供的驱动程序作为一个参数,直到返回值为 False。
Expected Conditions
在本例中,我们在使用 expected_conditions 类时对其时行了重命名,通过 as 关键字对其重命名为 EC,
并调用 presence_of_element_located()判断元素是否存在
expected_conditions 类提供一些预期条件的实现
title_is 用于判断标题是否xx
title_contains 用于判断标题是否包含xx信息
presence_of_element_located 元素是否存在
visibility_of_element_located 元素是否可见
visibility_of 是否可见
presence_of_all_elements_located 判断一组元素是否存在
text_to_be_present_in_element 判断元素是否有xx文本信息
text_to_be_present_in_element_value 判断元素值是否有xx文本信息
frame_to_be_available_and_switch_to_it 表单是否可用,并切换到该表单
invisibility_of_element_located 判断元素是否隐藏
element_to_be_clickable 判断元素是否点击,她处于可见和启动状态
staleness_of 等到一个元素不再依附于DOM
element_to_be_selected 被选中的元素
element_located_to_be_selected 一个期望的元素位于被选中
element_selection_state_to_be 一个期望检查如果给定的元素被选中
element_located_selection_state_to_be 期望找到一个元素并检查是否选择状态
alert_is_present 预期一个警告信息 除了 expected_conditions 所提供的预期方法,我们也可以使用前面学过的 is_displayed()方法来判断元
素是否可见
#栗子 隐式等待1
from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.support.ui import WebDriverWait
driver = webdriver.Chrome()
driver.implicitly_wait(10) #10秒
driver.get('http://www.baidu.com')
input_ = driver.find_element(By.ID,'kw222')
input_.send_keys('selenium')
#结果
#AttributeError: 'NoneType' object has no attribute 'send_keys'
#栗子 隐式等待2
from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.support.ui import WebDriverWait
driver = webdriver.Chrome()
driver.implicitly_wait(10) #10秒
driver.get('http://www.baidu.com')
input_ = driver.find_element(By.ID,'kw')
input_.send_keys('selenium')
#结果,不报错
#栗子 sleep 休眠方法
from selenium import webdriver
from selenium.webdriver.common.by import By
from time import sleep
driver = webdriver.Chrome()
driver.get('http://www.baidu.com')
sleep(2)
driver.find_element(By.ID,'kw').send_keys('selenium')
driver.find_element(By.ID,'su').click()
sleep(3)
#栗子 定位一组元素
在当前文件夹下创建checkbox.html
<html>
<head>
<meta http-equiv="content-type" content="text/html;charset=utf-8" />
<title>Checkbox</title>
<link href="http://cdn.bootcss.com/bootstrap/3.3.0/css/bootstrap.min.css"
rel="stylesheet" />
<script
src="http://cdn.bootcss.com/bootstrap/3.3.0/css/bootstrap.min.js"></script>
</head>
<body>
<h3>checkbox</h3>
<div class="well">
<form class="form-horizontal">
<div class="control-group">
<label class="control-label" for="c1">checkbox1</label>
<div class="controls">
<input type="checkbox" id="c1" />
</div>
</div>
<div class="control-group">
<label class="control-label" for="c2">checkbox2</label>
<div class="controls">
<input type="checkbox" id="c2" />
</div>
</div>
<div class="control-group">
<label class="control-label" for="c3">checkbox3</label>
<div class="controls">
<input type="checkbox" id="c3" />
</div>
</div>
</form>
</div>
</body>
</html>
执行以下代码:
from selenium import webdriver
from selenium.webdriver.common.by import By
import os
driver = webdriver.Chrome()
file_path = 'file:///' + os.path.abspath('checkbox.html')
file_path = file_path.replace('\\','/')
driver.get(file_path)
#选择页面上所有的tag name 为input 的元素
inputs = driver.find_elements_by_tag_name('input')
#然后从中过滤出type 为checkout的元素,单机勾选
for i in inputs:
if i.get_attribute('type') == 'checkbox':
i.click()
# 栗子 定位一组元素 XPATH 和 CSS 方式
from selenium import webdriver
from selenium.webdriver.common.by import By
import os
driver = webdriver.Chrome()
file_path = 'file:///' + os.path.abspath('checkbox.html')
file_path = file_path.replace('\\','/')
driver.get(file_path)
#通过Xpath找到type=checkbox的元素
checkboxes = driver.find_elements(By.XPATH,"//input[@type='checkbox']")
#通过css找到type=checkbox的元素
#checkboxes = driver.find_element(By.CSS_SELECTOR,'input[type=checkbox]')
for checkbox in checkboxes:
checkbox.click()
#打印当前页面上的type为checkbox的个数
print(len(checkboxes))
#吧页面上最后一个checkbox的钩给去掉
driver.find_elements(By.CSS_SELECTOR,'input[type=checkbox]').pop().click()
#栗子 frame,报错的
from selenium import webdriver
from selenium.webdriver.common.by import By
import os
import time
driver = webdriver.Chrome()
file_path = 'file:///' + os.path.abspath('frame.html')
file_path = file_path.replace('\\','/')
driver.get(file_path)
#
driver.find_element(By.ID,'kw').send_keys('selenium2')
driver.find_element(By.ID,'su').click()
time.sleep(3)
#【结果】no such element
#栗子 frame 正常的 根据id来定位
from selenium import webdriver
from selenium.webdriver.common.by import By
import os
import time
driver = webdriver.Chrome()
file_path = 'file:///' + os.path.abspath('frame.html')
file_path = file_path.replace('\\','/')
driver.get(file_path)
#切换到iframe(id='if')
driver.switch_to_frame('if')
#然后就可以正常操作元素了
driver.find_element(By.ID,'kw').send_keys('selenium2')
driver.find_element(By.ID,'su').click()
time.sleep(3)
#栗子 frame 正常的 根据name来定位
from selenium import webdriver
from selenium.webdriver.common.by import By
import os
import time
driver = webdriver.Chrome()
file_path = 'file:///' + os.path.abspath('frame.html')
file_path = file_path.replace('\\','/')
driver.get(file_path)
#切换到iframe(name='nf')
driver.switch_to_frame('nf')
#然后就可以正常操作元素了
driver.find_element(By.ID,'kw').send_keys('selenium2')
driver.find_element(By.ID,'su').click()
time.sleep(3)
# 栗子 根据父节点或本节点的其他方式定位
from selenium import webdriver
from selenium.webdriver.common.by import By
import os
import time
driver = webdriver.Chrome()
file_path = 'file:///' + os.path.abspath('frame.html')
file_path = file_path.replace('\\','/')
driver.get(file_path)
#切换到iframe(name='nf')
#根据父节点定位
iframe = driver.find_element(By.XPATH,"//div[@class='span10 well']/iframe")
#根据本节点定位
#iframe = driver.find_element(By.XPATH,"//iframe")
driver.switch_to_frame(iframe)
#然后就可以正常操作元素了
driver.find_element(By.ID,'kw').send_keys('selenium2')
driver.find_element(By.ID,'su').click()
time.sleep(3)
driver.switch_to_default_content()
#栗子 窗口切换
from selenium import webdriver
from selenium.webdriver.common.by import By
driver = webdriver.Chrome()
driver.implicitly_wait(10)
driver.get('http://www.baidu.com')
#获得百度搜索窗口句柄
search_window = driver.current_window_handle
driver.find_element(By.LINK_TEXT,u'登录').click()
driver.find_element(By.LINK_TEXT,u'立即注册').click()
#获得当前所有打开的窗口的句柄
all_handles = driver.window_handles
#进入注册窗口
for handle in all_handles:
if handle != search_window:
driver.switch_to_window(handle)
print('now register window')
driver.find_element(By.NAME,'userName').send_keys('username___9')
#进入搜索窗口
for handle in all_handles:
if handle == search_window:
driver.switch_to_window(handle)
print('now search window')
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()
# 栗子 警告框处理
from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.common.action_chains import ActionChains
from selenium.webdriver.support.ui import WebDriverWait
from selenium.webdriver.support import expected_conditions
driver = webdriver.Chrome()
driver.implicitly_wait(10)
driver.get('http://www.baidu.com')
#鼠标悬停“设置”连接
link = driver.find_element(By.LINK_TEXT,u'设置')
ActionChains(driver).move_to_element(link).perform()
#打开搜索设置
driver.find_element(By.CLASS_NAME,'setpref').click()
#保存设置
#element = WebDriverWait(driver,5,0.5).until(expected_conditions.element_to_be_clickable((By.CSS_SELECTOR,'#gxszButton>a.prefpanelgo')))
if driver.find_element(By.CSS_SELECTOR,'#gxszButton>a.prefpanelgo').is_displayed():
driver.find_element(By.CSS_SELECTOR, '#gxszButton>a.prefpanelgo').click()
# 接收弹窗
driver.switch_to_alert().accept()
# 栗子 文件上传 send_keys 实现上传
upfile.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta http-equiv="content-type" content="text/html" charset="UTF-8">
<title>upload_file</title>
<link href="http://cdn.bootcss.com/bootstrap/3.3.0/css/bootstrap.min.css" rel="stylesheet">
<script src="http://cdn.bootcss.com/bootstrap/3.3.0/css/bootstrap.min.js"></script>
</head>
<body>
<div class="row-fluid">
<div class="span6 well">
<h3>upload_file</h3>
<input type="file" name="file" />
</div>
</div>
</body>
</html>
脚本
from selenium import webdriver
from selenium.webdriver.common.by import By
import os
driver = webdriver.Chrome()
#打开上传功能页面
file_path = 'file:///' + os.path.abspath('upfile.html')
file_path = file_path.replace('\\','/')
driver.get(file_path)
#定位上传按钮,添加本地文件
driver.find_element(By.NAME,'file').send_keys('D:\\upload_file.txt')
#栗子 cookie
from selenium import webdriver
from selenium.webdriver.common.by import By
import os
driver = webdriver.Chrome()
driver.get('http://www.youdao.com')
#获得cookie信息
cookie = driver.get_cookies()
#打印
print(cookie)
#结果:
[{u'domain': u'.youdao.com',
u'secure': False,
u'value': u'aGFzbG9nZ2VkPXRydWU=',
u'expiry': 1408430390.991375,
u'path': u'/',
u'name': u'_PREF_ANONYUSER__MYTH'},
{u'domain': u'.youdao.com',
u'secure': False,
u'value': u'1777851312@218.17.158.115',
u'expiry': 2322974390.991376,
u'path': u'/', u'name':
u'OUTFOX_SEARCH_USER_ID'},
{u'path': u'/',
u'domain': u'www.youdao.com',
u'name': u'JSESSIONID',
u'value': u'abcUX9zdw0minadIhtvcu',
u'secure': False}]
#栗子 操作cookie
from selenium import webdriver
from selenium.webdriver.common.by import By
import os
driver = webdriver.Chrome()
driver.get('http://www.youdao.com')
#向cookie的name 和 value 添加回话信息
driver.add_cookie({'name':'key-aaaaaaaa','value':'value-bbbbb'})
#遍历cookies 中的name 和value信息打印,当然还有上面添加的信息
for cookie in driver.get_cookies():
print('%s -> %s' % (cookie['name'],cookie['value']))
#结果
OUTFOX_SEARCH_USER_ID -> -2105560286@220.248.17.218
DICT_UGC -> be3af0da19b5c5e6aa4e17bd8d90b28a|
JSESSIONID -> abcbl2cYr1e9V9KYhHIbw
OUTFOX_SEARCH_USER_ID_NCOO -> 707927902.8917714
___rl__test__cookies -> 1513481263502
key-aaaaaaaa -> value-bbbbb
#栗子 js 页面滚动条
from selenium import webdriver
from selenium.webdriver.common.by import By
import time
driver = webdriver.Chrome()
driver.get('http://www.baidu.com')
#搜索
driver.find_element(By.ID,'kw').send_keys('selenium')
driver.find_element(By.ID,'su').click()
time.sleep(3)
#将页面滚动条拖到底部
js = 'var q = document.body.scrollTop=10000'
driver.execute_script(js)
time.sleep(3)
#将页面滚动条拖到顶部
js_ = 'var q = document.body.scrollTop=0'
driver.execute_script(js_)
time.sleep(3)
# 栗子 窗口截图
from selenium import webdriver
from selenium.webdriver.common.by import By
import time
driver = webdriver.Chrome()
driver.get('http://www.baidu.com')
try:
driver.find_element('kw_error').send_keys('selenium')
driver.find_element('su').click()
except:
driver.get_screenshot_as_file('baidu_error.jpg')
# 在当前文件夹下生成错误截图
#栗子 退出
quit()方法,其含义为退出相关的驱动程序和关闭所有窗口
只能关闭其中的某一个窗口,这个时候就需要使用 close()来关闭
#栗子 debug
from selenium import webdriver
import logging
logging.basicConfig(level=logging.DEBUG)
diver = webdriver.Chrome()
diver.get("http://www.baidu.com")
diver.find_element_by_id("kw").send_keys("selenium")
diver.find_element_by_id("su").click()
#栗子 【自动化测试模型】【数据驱动】 qq邮箱
from selenium import webdriver
from selenium.webdriver.common.by import By
import time
driver = webdriver.Chrome()
driver.implicitly_wait(10)
driver.get("http://mail.qq.com")
class Account(object):
def __init__(self,username='',password=''):
self.username = username
self.password = password
def do_login_as(user_info):
if driver.find_element(By.CSS_SELECTOR, 'iframe#login_frame').is_displayed():
driver.switch_to.default_content()
driver.switch_to.frame(driver.find_element(By.CSS_SELECTOR, 'iframe#login_frame'))
driver.find_element(By.LINK_TEXT, '帐号密码登录').click()
driver.find_element(By.XPATH, ".//*[@id='u']").clear()
driver.find_element(By.XPATH, ".//*[@id='u']").send_keys(user_info.username)
driver.find_element(By.XPATH, ".//*[@id='p']").clear()
driver.find_element(By.XPATH, ".//*[@id='p']").send_keys(user_info.password)
driver.find_element(By.CSS_SELECTOR, 'input#login_button').click()
wxue = Account(username='981094301@qq.com',password='9(zndxcpvsWWXX')
#调用登录函数
do_login_as(wxue)
#栗子 【自动化测试模型】【数据驱动】百度搜索
建文件夹,下面两个文件,一个.txt,一个.py
user_info.txt
zhangsan,123
lisi,456
wagnwu,789
test.py
from selenium import webdriver
user_file = open('user_info.txt','r')
values = user_file.readlines()
user_file.close()
for search in values:
username = search.split(',')[0]
print(username)
password = search.split(',')[1]
print(password)
#栗子 【自动化测试模型】【数据驱动】读取csv文件
.csv 文件,在pycharm中的文件内容显示如下:
username,password
testing,123@126.com
testing1,123@qq.com
.py 文件:
from selenium import webdriver
import csv
#获取csv文件中password列
with open(r'info.csv','r',encoding='utf-8') as csvfile:
text=csv.DictReader(csvfile)
pwd=[row['password'] for row in text]
#获取csv文件中username列
with open(r'info.csv','r',encoding='utf-8') as csvfile:
text=csv.DictReader(csvfile)
user=[row['username'] for row in text]
#打印出来以列表形式,也可以获取单条数据
print(user,pwd)
#结果
['testing', 'testing1'] ['123@126.com', '123@qq.com']
# 常用方法
assertIs(first, second, msg=None)
assertIsNot(first, second, msg=None)
测试第一个和第二个是否为同一对象。
assertIsNone(expr, msg=None)
assertIsNotNone(expr, msg=None)
测试表达式是否为 None 对象。
assertIsInstance(obj, cls, msg=None)
assertNotIsInstance(obj, cls, msg=None)
测试对象(obj)是否有一个实例(cls)