python实例编写(2)--等待,一组对象,层级元素,frame对象处理

一.设置等待

#coding=utf-8

from selenium import webdriver
from selenium.webdriver.support.ui  import WebDriverWait
from time import sleep

driver=webdriver.Chrome()
driver.get(‘http://www.baidu.com‘)

#添加智能等待
driver.implicitly_wait(3)
driver.find_element_by_id("su").click()

#添加固定等待
sleep(3)
driver.find_element_by_link_text("登录").click()

#使用WebDriverWait方法,和until(method,message)以及 until_not(method,message),lambda提供一个运行时创建动态函数的方法
element=WebDriverWait(driver,5).until(lambda x:x.find_element_id("TANGRAM__PSP_2__closeBtn"))
element.click()

二. 多选框,组对象

新建文件checkbox.html

<html  lang="zh-cn">
    <head>
        <meta http-equiv="content-type" content="text/html;charset=utf-8" />
        <title>Checkbox</title>
        <script type="text/javascript" async="" src="https://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
        <link href="http://netdna.bootstrapcdn.com/twitter-bootstrap/2.3.2/css/bootstrap-combined.min.css" rel="stylesheet" />
        <script src="http://netdna.bootstrapcdn.com/twitter-bootstrap/2.3.2/js/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>
                <div class="control-group">
                    <label class="control-label" for="r">radio</label>
                    <div class="controls">
                        <input type="radio" id="r" />
                    </div>
                </div>
            </form>
        </div>
    </body>
</html>

  创建elements.py

# -*- coding: cp936 -*-
# coding =utf-8
from selenium import webdriver
import os


#path.abspath()获取当前路径下的文件,所以html文件必须和本文件地址一致

driver=webdriver.Chrome()
file_path=‘file:///‘+os.path.abspath("checkbox.html")
driver.get(file_path)

#选择页面标签元素为 input的
#len为显示长度,pop删除指定位置的元素,默认为最后一个,由0开始
inputs=driver.find_elements_by_tag_name(‘input‘)
for input in inputs:
    if input.get_attribute(‘type‘)==‘checkbox‘:
        input.click()
print len(driver.find_elements_by_css_selector(‘input[type=checkbox]‘))
print driver.find_elements_by_css_selector(‘input[type=checkbox]‘).pop(0).click()

#或者可以直接定位复选框
inputs=driver.find_elements_by_css_selector(‘input[type=checkbox]‘)
#报错内容:TypeError: ‘WebElement‘ object is not iterable,用elements 而不是 element
#对于以:结尾的,次行需要缩进

三.层级定位,子元素属性相同的,先定位父元素,再定位子元素,二级定位

创建locate.html

<html>
    <head>
        <meta http-equiv="content-type" content="text/html;charset=utf-8"  />
        <title>Level Locate</title>
        <script type="text/javascript" async="" src="http://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
        <link href="http://netdna.bootstrapcdn.com/twitter-bootstrap/2.3.2/css/bootstrap-combined.min.css" rel="stylesheet"  />
    </head>
    <body>
        <h3>Level locate</h3>
        <div class="span3">
            <div class="well">
                <div class="dropdown">
                    <a class="dropdown-toggle" data-toggle="dropdown" href="#">Link1</a>
                    <ul class="dropdown-menu" role="menu" aria-labelledby="dLabel" id="dropdown1" >
                        <li><a tabindex="-1" href="#">Action</a></li>
                        <li><a tabindex="-1" href="#">Another action</a></li>
                        <li><a tabindex="-1" href="#">Something else here</a></li>
                        <li class="divider"></li>
                        <li><a tabindex="-1" href="#">Separated link</a></li>
                    </ul>
                </div>
            </div>
        </div>
        <div class="span3">
            <div class="well">
                <div class="dropdown">
                    <a class="dropdown-toggle" data-toggle="dropdown" href="#">Link2</a>
                    <ul class="dropdown-menu" role="menu" aria-labelledby="dLabel" >
                        <li><a tabindex="-1" href="#">Action</a></li>
                        <li><a tabindex="-1" href="#">Another action</a></li>
                        <li><a tabindex="-1" href="#">Something else here</a></li>
                        <li class="divider"></li>
                        <li><a tabindex="-1" href="#">Separated link</a></li>
                    </ul>
                </div>
            </div>
        </div>
    </body>
    <script src="http://netdna.bootstrapcdn.com/twitter-bootstrap/2.3.2/js/bootstrap.min.js"></script>
</html>

  

思路:找到第一个下拉框,确定ul,定位子菜单

脚本编写如下:

#coding=utf-8

from  selenium import webdriver
from  time import sleep
from  selenium.webdriver.support.ui  import WebDriverWait
from  selenium.webdriver.common.action_chains import ActionChains
import os

dr=webdriver.Chrome()
file_path=‘file:///‘+os.path.abspath(‘secondlocate.html‘)
dr.get(file_path)

#点击link1链接(直接用click,使之弹出子菜单)
dr.find_element_link_text(‘link1‘).click()

#查找父元素的子元素,先定位下拉菜单,再定位选项,二级定位!!!
submenu=dr.find_element_by_id(‘dropdown1‘).find_element_by_link_text(‘Another action‘)

#鼠标移动到子元素上并点击,ActionChains(dr)生成用户实例,存储鼠标对象,move_to_element用于鼠标移动到元素上,perform用于执行存储元素的行为
ActionChains(dr).move_to_element(submenu).perform()

sleep(3)
dr.quit()

 四.html中嵌套html,即iframe,常见有UE编辑器(使用dr.swicth_to_frame(frame的id))

frame.html (f1)镶嵌  inner.html(f2)

frame.html

<html>
<head>
<meta http-equiv="content-type" content="text/html;charset=utf-8"  />
<title>frame</title>
<script type="text/javascript" async=""
src="http://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js
"></script>
<link href="http://netdna.bootstrapcdn.com/twitter-bootstrap/2.3.2/css/bootstrap-combined.min.css" rel="stylesheet"  />
<script type="text/javascript">
$(document).ready(function(){
});
</script>
</head>
<body>
<div class="row-fluid">
<div class="span10 well">
<h3>frame</h3>
<iframe id="f1" src="inner.html" width="800",
height="600"></iframe>
</div>
</div>
</body>
<script src="http://netdna.bootstrapcdn.com/twitter-bootstrap/2.3.2/js/bootstrap.min.js"></script>
</html>

  inner.html

<html>
<head>
<meta http-equiv="content-type" content="text/html;charset=utf-8"  />
<title>inner</title>
</head>
<body>
<div class="row-fluid">
<div class="span6 well">
<h3>inner</h3>
<iframe id="f2" src="http://www.baidu.com" width="700"
height="500"></iframe>
<a href="javascript:alert(‘watir-webdriver better than
selenium webdriver;‘)">click</a>
</div>
</div>
</body>
</html>

  效果图如下:

frame.py

#encoding=utf-8
from selenium import webdriver
from time import sleep
import os

dr=webdriver.Chrome()
file_path=‘file:///‘+os.path.abspath(‘frame.html‘)
dr.get(file_path)

#找到页面,等待,frame中,f1嵌套f2,f2里面显示的是百度首页,用dr.switch_to_frame()即可
dr.implicitly_wait(30)
#先找到f1,再找到f2
dr.switch_to_frame("f1")
dr.switch_to_frame("f2")

#定位元素即可
dr.find_element_by_id("kw").send_keys("haha")
dr.find_element_by_id("su").click()

dr.quit()

  

 

时间: 2024-10-09 15:06:12

python实例编写(2)--等待,一组对象,层级元素,frame对象处理的相关文章

python实例编写(7)---测试报告与测试套件(多个py文件,1个py文件内多个用例)

一.  一个.py文件批量执行测试用例(一个.py文件下多个用例执行) 如果直接使用:unittest.main(),则按字母顺序执行, 对于前后之间又依赖关系的用例,需要按特定的顺序执行,则使用 suite.addTest(类名("方法名")),如这里按照新增,修改,删除的顺序,可以避免执行完毕后的测试数据处理. def test_modifyCategory(self): ... def test_addCategory(self): ... def test_delCategor

python实例编写(5)--异常处理,截图,用例设计

一.python的异常处理 异常抛出处理机制: 1.若在运行时发生异常,解释器会查找相应的处理语句(handler) 2.若在当前函数无法找到,就将异常传给上层的调用函数,看是否能处理 3.如果在最外层(全局“main")中还是无法找到时,解释器退出,并打印出 traceback让用户找出错原因 try...except   异常捕捉,用except接收了这个IOError,pass代表实现了相应实现,什么也不做 #coding=utf-8 # except接收错误,不报错,pass代表实现了相

python实例编写(3)--对话框,多窗口,下拉框,上传文件

一.对话框: 例:点击百度的登录,弹出的小窗口 #coding=utf-8 from selenium import webdriver from time import sleep dr=webdriver.Chrome() dr.get("http://www.baidu.com") #一定要记得设置等待时间,要不然定位不到!!! dr.find_element_by_link_text("登录").click() sleep(3) #思路:二次定位,点击登录后

Effective Python之编写高质量Python代码的59个有效方法

                                                     这个周末断断续续的阅读完了<Effective Python之编写高质量Python代码的59个有效方法>,感觉还不错,具有很大的指导价值.下面将以最简单的方式记录这59条建议,并在大部分建议后面加上了说明和示例,文章篇幅大,请您提前备好瓜子和啤酒! 1. 用Pythonic方式思考 第一条:确认自己使用的Python版本 (1)有两个版本的python处于活跃状态,python2和pyt

【转载】python实例手册

今天西爬虫的时候遇到了问题,在网上不停地查找资料,居然碰到两篇好文章: 1.python实例手册   作者:没头脑的土豆 另一篇在这:shell实例手册 python实例手册 #encoding:utf8 # 设定编码-支持中文 0说明 手册制作: 雪松 更新日期: 2013-12-19 欢迎系统运维加入Q群: 198173206 # 加群请回答问题 请使用"notepad++"打开此文档,"alt+0"将函数折叠后方便查阅 请勿删除信息,转载请说明出处,抵制不道德

python实例手册

python实例手册 #encoding:utf8 # 设定编码-支持中文 0说明 手册制作: 雪松 更新日期: 2013-12-19 欢迎系统运维加入Q群: 198173206 # 加群请回答问题 请使用"notepad++"打开此文档,"alt+0"将函数折叠后方便查阅 请勿删除信息,转载请说明出处,抵制不道德行为. 错误在所难免,还望指正! # python实例手册下载地址: http://hi.baidu.com/quanzhou722/item/cf447

Python :编写条件分支代码的技巧

『Python 工匠』是什么? 我一直觉得编程某种意义是一门『手艺』,因为优雅而高效的代码,就如同完美的手工艺品一样让人赏心悦目. 在雕琢代码的过程中,有大工程:比如应该用什么架构.哪种设计模式.也有更多的小细节,比如何时使用异常(Exceptions).或怎么给变量起名.那些真正优秀的代码,正是由无数优秀的细节造就的. 序言 编写条件分支代码是编码过程中不可或缺的一部分. 如果用道路来做比喻,现实世界中的代码从来都不是一条笔直的高速公路,而更像是由无数个岔路口组成的某个市区地图.我们编码者就像

python基础-第七篇-7.1初识类和对象

创建类和对象 刚开始我们接触得多的编程方式为面向过程编程,这种方式就是根据业务逻辑从上往下垒代码,后来又出现了函数式编程,就是为了提高代码的重用性,减轻程序猿的工作量--而今天我们即将学的 面向对象编程则是使用类和对象来实现的,类就是一个模板,模板里可以包含多个函数,函数里实现一些功能 对象则是根据模板创建的实例,通过实例对象可以执行类中的函数 class是关键字,表示类 创建对象--类名称后加括号 #创建类 class foo: def bar(self): print('bar') def

Python实例 贴吧签到

第一步 查看HTTP请求的内容 首先需要通过浏览器或者其他http包分析软件来观察,签到的时候进行了什么请求. Firefox浏览器就足以做到这一点,Wireshark是更加专业的包分析软件,它除了能够分析HTTP协议的包,还能分析几乎所有通信协议的包. 签到的请求是一个POST请求,找到那个请求并点击,再在弹出的选项卡中选择参数,就可以看到POST的数据了 POST的数据有三项, 第一项是请求的编码,每次请求都不需要改变, 'kw'参数便是签到的贴吧名称, 第三个参数有点像是个密码,它其实由两