__author__ = 'Mickey0s'
# coding:utf8 from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.support.ui import WebDriverWait as wdw
from selenium.webdriver.support import expected_conditions as ec
from random import randint
from time import sleep dr = webdriver.Ie()
url = u'http://s.cr-nielsen.com/q/402/cn0376/html/402.htm' def singleradio(na): wdw(dr, 10).until(ec.presence_of_element_located((By.CSS_SELECTOR, 'input[type="radio"]')))
radios = dr.find_elements_by_css_selector('input[type="radio"]')
if len(radios) > 3:
if na == 'Q1':
radios[2].click()
else:
radios[randint(0, len(radios)-3)].click()
else:
radios[0].click() dr.find_element_by_class_name('submit-button').click()
sleep(1)
return dr.window_handles def textfill(na):
wdw(dr, 10).until(ec.presence_of_all_elements_located)
texts = dr.find_element_by_name(na).find_elements(By.CSS_SELECTOR, 'input[type=text]')
for i in texts:
i.send_keys('i am a fish!') dr.find_element_by_class_name('submit-button').submit()
sleep(1)
return dr.window_handles def tableradio(na): tables = dr.find_element_by_name(na).find_element_by_tag_name('tbody').find_elements_by_tag_name('tr')
for i in tables[:]:
dr.implicitly_wait(3)
tem = i.find_elements_by_tag_name('td')
wdw(dr, 10).until(ec.presence_of_all_elements_located)
t = tem[randint(1, len(tem)-1)].find_element_by_tag_name('input')
if ec.element_to_be_clickable(t):
t.click() dr.find_element_by_class_name('submit-button').submit()
sleep(1)
return dr.window_handles def checkbox(na):
wdw(dr, 10).until(ec.presence_of_element_located((By.CSS_SELECTOR, 'input[type="checkbox"]')))
boxs = dr.find_elements_by_css_selector('input[type="checkbox"]')
boxs.pop(-2)
l = len(boxs)
for i in boxs:
if randint(0, l-1)%2 == 0:
i.click()
dr.find_element_by_class_name('submit-button').submit()
sleep(1)
return dr.window_handles page = {'Q1': (singleradio, '请问,您的年龄是?(单选)'),
'Q1B': (textfill, '想到的是哪些品牌'),
'Q2B': (tableradio, '品牌的熟悉程度?(横向单选)'),
'Q3B': (tableradio, '总体评价是?(横向单选)'),
'Q4B': (tableradio, '购买以下品牌的可能性有多大? (横向单选)'),
'Q5B': (singleradio, '倾向购买以下哪个品牌?(单选) '),
'Q6B': (tableradio, '同意程度如何?(每行单选) '),
'Q1Ca': (singleradio, '是否看到过这个视频广告?[单选]'),
'Q2Ca': (singleradio, '多喜欢这个广告?[单选]'),
'Q2Cb': (singleradio, '多喜欢这个广告?[单选]'),
'Q3Ca': (checkbox, '哪些方面是您所喜欢的?[可多选] '),
'Q3Cb': (checkbox, '哪些方面是您所喜欢的?[可多选] '),
'Q4Ca': (checkbox, '您所不喜欢的?[可多选]'),
'Q5Ca': (singleradio, '哪一项符合这个广告?[单选]'),
'Q6Ca': (tableradio, '是否同意下列描述?[每行单选] '),
'Q1Cb': (singleradio, '看到过这个视频广告?[单选]'),
'Q1D': (singleradio, '图片广告(横幅、竖栏、浮层等)?[单选]'),
'Q1S': (singleradio, '性别是?(单选)'),
'Q2S': (singleradio, '学历是?(单选)'),
'Q3S': (singleradio, '职业是?(单选) '),
'Q4S': (singleradio, '税前个人月收入?(单选) '),
'Q5S': (singleradio, '孩子多大了?(单选) '),
'Q6S': (singleradio, '阅读几本书籍'),
'Q7S': (checkbox, '哪些电子设备?(可多选) '),
'Q8S': (checkbox, '哪些电子设备?(可多选) '), } try:
dr.get(url)
frame = dr.find_elements_by_tag_name('frame')
if len(frame) == 1:
dr.switch_to_frame(frame[0]) for e in page: te = dr.find_element_by_css_selector('a[name]')
tt = te.get_attribute('name')
print tt
try:
w = page[tt][0](tt)
finally:
print 0 dr.switch_to_window(w[-1])
frame = dr.find_elements_by_tag_name('frame')
if len(frame) == 1:
dr.switch_to_frame(frame[0]) finally:
sleep(5)
dr.quit()

-------------------------

btw: 练习项目,非正式

1. 对一种类型的页面,类似的操作包装成函数

2. 试着使用page factory, 元素、操作、数据分离(这个练习没有多少数据)

3. 元素定位,对于复杂的元素定位,还是要用CSS、xpath

4. 判断每个页面的类型,在字典中选择对应类型的操作。此练习使用的 关键字

5.点击下一个页面后,用一遍dr.switch_to_window(w[-1]),没检验过是否必要

 dr.switch_to_window(w[-1])
frame = dr.find_elements_by_tag_name('frame')
if len(frame) == 1:
dr.switch_to_frame(frame[0]) 未解决: 总结4 中使用关键字,定位页面类型,实际上关键字会变动,导致失败,应该使用更好的判断方法

  

  

  

python webdriver 自动化测试练习 1-- 在线调查的更多相关文章

  1. 转来的——python webdriver自动化测试初步印象——转来的

    python webdriver自动化测试初步印象 以下示例演示启动firefox,浏览google.com,搜索Cheese,等待搜索结果,然后打印出搜索结果页的标题 from selenium i ...

  2. Python WebDriver自动化测试

    转载来自: http://www.cnblogs.com/fnng/p/3160606.html Webdriver Selenium 是 ThroughtWorks 一个强大的基于浏览器的开源自动化 ...

  3. 前端自动化测试python+webdriver

    前言:很多做测试的朋友的就知道,python+webdriver  可以做自动化测试,这对前端开发是非常有用的.  python 入门我就不讲了  ,推荐学习 廖雪峰老师的python入门3.5新版哈 ...

  4. 基于Appium、Python的自动化测试

    基于Appium.Python的自动化测试环境部署和实践   第一章 导言 1.1 编制目的 该文档为选用Appium作为移动设备原生(Native).混合(Hybrid).移动Web(Mobile ...

  5. 转:python webdriver API 之简单对象的定位

    对象(元素)的定位和操作是自动化测试的核心部分,其中操作又是建立在定位的基础上的,因此元素定位就显得非常重要. (本书中用到的对象与元素同为一个事物)一个对象就像是一个人,他会有各种的特征(属性) , ...

  6. 转:python webdriver 环境搭建

    第一节 环境搭建准备工具如下:-------------------------------------------------------------下载 python[python 开发环境]ht ...

  7. python selenium 自动化测试web

    如何使用python完成自动化测试web页面呢?首选selenium   那基于python的selenium如何使用,下面看一段测试案例: 基于python的selenium 安装方法: pip i ...

  8. [转]构建Python+Selenium2自动化测试环境(二)

    构建Python+Selenium2自动化测试环境完成之后,就需要测试支持python的selenium的版本是否都支持在不同浏览器上运行,当前我们分别在三个最通用的浏览器上通过脚本来测试. 1.在I ...

  9. Python Web自动化测试入门与实战,从入门到入行

    Python Web自动化测试入门与实战 购买地址 · 京东:https://item.jd.com/69239480564.html   天猫:https://detail.tmall.com/it ...

随机推荐

  1. asp.net链接数据库问题,设置收藏本站,设置主页

    SQL Server 2008附加数据库失败:无法打开物理文件拒绝访问解决方法 无法打开物理文件 "E:\SQLDATA\EMSXDB.mdf".操作系统错误 5:"5( ...

  2. .NET中的yield关键字

    浅谈yield http://www.cnblogs.com/qlb5626267/archive/2009/05/08/1452517.html .NET中yield关键字的用法 http://bl ...

  3. C++11 变长模版和完美转发实例代码

    C++11 变长模版和完美转发实例代码 #include <memory>#include <iostream>#include <vector>#include ...

  4. hadoop机架感知与网络拓扑分析:NetworkTopology和DNSToSwitchMapping

    hadoop网络拓扑结构在整个系统中具有很重要的作用,它会影响DataNode的启动(注册).MapTask的分配等等.了解网络拓扑对了解整个hadoop的运行会有很大帮助. 首先通过下面两个图来了解 ...

  5. number 数据类型的分析。

    在js中,number数据类型可能算最令人关注的的类型之一了. number类型分为整数和浮点数. 一,整型数,整型又分为十进制,八进制,十六进制. 十进制即是生活中接触到的:而八进制数的首位必须是零 ...

  6. pickle 序列化反序列化

    python的pickle模块实现了基本的数据序列和反序列化.通过pickle模块的序列化操作我们能够将程序中运行的对象信息保存到文件中去,永久存储:通过pickle模块的反序列化操作,我们能够从文件 ...

  7. Python中setuptools做什么用的?

    概括 setuptools是 Python Enterprise Application Kit(PEAK)的一个副项目,它 是一组Python的 distutilsde工具的增强工具(适用于 Pyt ...

  8. powershell读写磁盘变量(对象序列化)

    ---[第一章,开篇引子]--- 很久很久以前,我在网上闲逛,看到一头powershell菜鸟,写了一篇感慨道“挖哈哈,我学会powershell啦,我以前很笨,各种不懂,还想把变量保存起来.” 实际 ...

  9. 关于Erlang中的behaviour

    唔,听说过这四个牛逼渣渣的behaviour:gen_server,gen_fsm,gen_event,supervisor.所以也就更加好奇behaviour的实现. 在解释它是怎么工作的之前,我们 ...

  10. Spring IOC 依赖注入的两种方式XML和注解

    依赖注入的原理 依赖注入的方式---XML配置 依赖注入的方式---注解的方式 Spring 它的核心就是IOC和AOP.而IOC中实现Bean注入的实现方式之一就是DI(依赖注入). 一 DI的原理 ...