定位一组对象-checkbox 、radiobutton

webdriver 能够很方便的使用find_element 方法来定位某个特定的对象,不过有时候咱们却须要定位一组对象,WebElement 接口一样提供了定位一组元素的方法find_elements。javascript

定位一组对象通常用于如下场景:css

  •  批量操做对象,好比将页面上全部的checkbox 都勾上。
  •  先获取一组对象,再在这组对象中过滤出须要具体定位的一些对象。好比定位出页面上全部的checkbox,而后选择最后一个。

checkbox.html   html代码示例:html

<html>java


<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>python


    <body>
        <h3>checkbox</h3>
        <div class="well">
            <form class="form-horizontal">jquery


                 <div class="control-group">
                       <label class="control-label" for="c1">checkbox1</label>
                       <div class="controls">
                               <input type="checkbox" id="c1" />
                       </div>
                 </div>web


                 <div class="control-group">
                       <label class="control-label" for="c2">checkbox2</label>
                       <div class="controls">
                               <input type="checkbox" id="c2" />
                       </div>
                 </div>ajax


                 <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>bootstrap

 

补充后的HTML代码api

<html>
    <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="r1" />
                    </div>
                </div>
                
                <div class="control-group">
                    <label class="control-label" for="r">radio</label>
                    <div class="controls">
                        <input type="radio" id="r2" />
                    </div>
                </div>
            </form>
        </div>
    </body>
</html>

将这段代码保存复制到记事本中,将保存成checkbox.html 文件。(注意,这个页面须要和咱们的自动化脚本放在同一个目录下,不然下面的脚本将checkbox.html 的所在目录)
经过浏览器打开checkbox.html,将看到如下页面:

                                     图3.5

若是3.5所示:

能够看到页面提供了三个复选框和两个单选按钮。下面经过脚原本单击勾选三个复选框。

代码示例:

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

driver = webdriver.Firefox()
file_path = 'file:///' + os.path.abspath('checkbox.html')
driver.get(file_path)

# 选择页面上全部的tag name 为input 的元素
inputs = driver.find_elements_by_tag_name('input')

#而后从中过滤出tpye 为checkbox 的元素,单击勾选

for input in inputs:
if input.get_attribute('type') == 'checkbox':
input.click()

driver.quit()

 

你能够试着把input.get_attribute('type') == 'checkbox' 中的checkbox 变成radio ,那这个脚本定位的会是两个单选框

说明:

import os
os.path.abspath()

os 模块为python 语言标准库中的os 模块包含广泛的操做系统功能。主要用于操做本地目录文件。
path.abspath()方法用于获取当前路径下的文件。另外脚本中还使用到for 循环,对inputs 获取的一组元素进行循环,在python 语言中循环变量(input)能够不用事先声明直接使用。

find_elements_by_xx(‘xx’)
find_elements 用于获取一组元素。

 

下面经过css 方式来勾选一组元素,打印当所勾选元素的个数并对最后一个勾选的元素取消勾选。

 代码示例:

#coding=utf-8
from selenium import webdriver
import os


driveriver = webdriver.Firefox()
file_path = 'file:///' + os.path.abspath('checkbox.html')
driver.get(file_path)


# 选择全部的type 为checkbox 的元素并单击勾选
checkboxes = driver.find_elements_by_css_selector('input[type=checkbox]')


for checkbox in checkboxes:
checkbox.click()

# 打印当前页面上type 为checkbox 的个数
print len(driver.find_elements_by_css_selector('input[type=checkbox]'))

# 把页面上最后1个checkbox 的勾给去掉
driver.find_elements_by_css_selector('input[type=checkbox]').pop().click()

driver.quit()

 

说明:

len()
len 为python 语言中的方法,用于返回一个对象的长度(或个数)。

pop()
pop 也为python 语言中提供的方法,用于删除指定们位置的元素,pop()为空默认选择最一个元素。

 

 

尝试

 

把find_elements_by_css_selector('input[type=checkbox]').pop().click() 中的checkbox 变成radio 会是什么效果,本身尝试一下吧!

 

 

知识扩充:

参考博客地址:http://www.cnblogs.com/yoyoketang/p/6128675.html

相关文章
相关标签/搜索