您的位置:軟件測試 > 開源軟件測試 > 開源功能測試工具 > Selenium
輕松自動(dòng)化---selenium-webdriver(python) (四)
作者:網(wǎng)絡(luò)轉(zhuǎn)載 發(fā)布時(shí)間:[ 2013/8/12 14:49:14 ] 推薦標(biāo)簽:

  將這段代碼保存復(fù)制到記事本中,將保存成checkbox.html文件。(注意,這個(gè)頁面需要和我們的自動(dòng)化腳本放在同一個(gè)目錄下)

   check box

  第一種方法:

  通過瀏覽器打個(gè)這個(gè)頁面我們看到三個(gè)復(fù)選框和兩個(gè)單選框。下面我們來定位這三個(gè)復(fù)選框。

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

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

# 選擇頁面上所有的input,然后從中過濾出所有的checkbox并勾選之
inputs = dr.find_elements_by_tag_name('input')
for input in inputs:
    if input.get_attribute('type') == 'checkbox':
        input.click()
time.sleep(2)

dr.quit()

  你可以試著把input.get_attribute('type') == 'checkbox' 中的checkbox 變成radio ,那這個(gè)腳本定位的會(huì)是兩個(gè)單選框。

  第二種定位方法:

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

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

# 選擇所有的checkbox并全部勾上
checkboxes = dr.find_elements_by_css_selector('input[type=checkbox]')
for checkbox in checkboxes:
    checkbox.click()
time.sleep(2)

# 打印當(dāng)前頁面上有多少個(gè)checkbox
print len(dr.find_elements_by_css_selector('input[type=checkbox]'))
time.sleep(2)

dr.quit()

  第二種寫法與第一種寫法差別不大,都是通過一個(gè)循環(huán)來勾選控件;如果你學(xué)過上一章的話,細(xì)心的你一定發(fā)現(xiàn)用的定位函數(shù)不一樣,第一種用的name ,第二種用的CSS 。

  如何去掉勾選:

  還有一個(gè)問題,有時(shí)候我們并不想勾選頁面的所有的復(fù)選框(checkbox),可以通過下面辦法把后一個(gè)被勾選的框去掉。如下:

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

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

# 選擇所有的checkbox并全部勾上
checkboxes = dr.find_elements_by_css_selector('input[type=checkbox]')
for checkbox in checkboxes:
    checkbox.click()
time.sleep(2)

# 把頁面上后1個(gè)checkbox的勾給去掉
dr.find_elements_by_css_selector('input[type=checkbox]').pop().click()
time.sleep(2)

dr.quit()

  其實(shí),去掉勾選表也邏輯也非常簡單,是再次點(diǎn)擊勾選的按鈕。可能我們比較迷惑的是如何找到“后一個(gè)”按鈕。pop() 可以實(shí)現(xiàn)這個(gè)功能。

  好吧!在web自動(dòng)化的學(xué)習(xí)過程中,我們必須要知道一些前端的東西,這里擴(kuò)展一下:

  http://www.w3school.com.cn/js/jsref_pop.asp

  嘗試:

  把find_elements_by_css_selector('input[type=checkbox]').pop().click() 中的checkbox 變成radio 會(huì)是什么效果,自己嘗試一下吧!

相關(guān)鏈接:
上一頁12下一頁
軟件測試工具 | 聯(lián)系我們 | 投訴建議 | 誠聘英才 | 申請(qǐng)使用列表 | 網(wǎng)站地圖
滬ICP備07036474 2003-2017 版權(quán)所有 上海澤眾軟件科技有限公司 Shanghai ZeZhong Software Co.,Ltd