【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 的驱动程序(IeFirefoxChrome 等)
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)




































































posted @ 2017-12-13 19:56  素人渔芙2017  阅读(332)  评论(0编辑  收藏  举报