Python利用splinter實(shí)現(xiàn)瀏覽器自動(dòng)化操作方法
利用Splinter開發(fā)瀏覽器自動(dòng)化操作,編寫代碼比較簡(jiǎn)單。
案例一:
from splinter import Browser with Browser() as browser: # Visit URL url = "http://www.google.com" browser.visit(url) browser.fill('q', 'splinter - python acceptance testing for web applications') # Find and click the 'search' button button = browser.find_by_name('btnG') # Interact with elements button.click() if browser.is_text_present('splinter.readthedocs.io'): print("Yes, the official website was found!") else: print("No, it wasn't found... We need to improve our SEO techniques")
第1行 是導(dǎo)入Browser。
Browser是整個(gè)測(cè)試的基礎(chǔ),你可以把它理解為一個(gè)瀏覽器。
第3行 初始化一個(gè)Browser,不加參數(shù)的話默認(rèn)是firefox。
第4行 是命令browser打開"http://google.com"。
第5行 是命令browser使用‘splinter - python acceptance testing for web applications'填充頁(yè)面中‘name'是‘q'的元素。在Google的首頁(yè)中,就是那個(gè)搜索框。大家可以看一下Google首頁(yè)的代碼。
第6行 是兩個(gè)命令。第一個(gè)是找到‘name'屬性為‘btnG'的按鈕,第二個(gè)是click()也就是點(diǎn)擊這個(gè)按鈕。這個(gè)按鈕就是Google的搜索按鈕。
第8行 是判斷頁(yè)面中是否有‘splinter.cobrateam.info'這個(gè)字符串,因?yàn)樯弦徊近c(diǎn)擊了搜索按鈕,所以這里搜索的就是跳轉(zhuǎn)之后的頁(yè)面。當(dāng)然,大家不用擔(dān)心網(wǎng)速慢會(huì)判斷出錯(cuò),splinter會(huì)等頁(yè)面載入完成再進(jìn)行下一步的操作。
第13行 是刪除browser。
案例二:
這里,我給出自動(dòng)登錄126郵箱的案例。難點(diǎn)是要找到頁(yè)面的賬戶、密碼、登錄的頁(yè)面元素,這里需要查看126郵箱登錄頁(yè)面的源碼,才能找到相關(guān)控件的id.
例如:輸入密碼,密碼的文本控件id是pwdInput.可以使用browser.find_by_id()方法定位到密碼的文本框,
接著使用fill()方法,填寫密碼。至于模擬點(diǎn)擊按鈕,也是要先找到按鈕控件的id,然后使用click()方法。
由于代碼較簡(jiǎn)單,我就只在代碼中給出注解說(shuō)明工作原理。
#coding=utf-8 import time from splinter import Browser def splinter(url): browser = Browser('chrome') #login 126 email websize browser.visit(url) #wait web element loading time.sleep(5) #fill in account and password browser.find_by_id('idInput').fill('xxxxxx') browser.find_by_id('pwdInput').fill('xxxxx') #click the button of login browser.find_by_id('loginBtn').click() time.sleep(8) #close the window of brower browser.quit() if __name__ == '__main__': websize3 ='http://www.126.com' splinter(websize3)
以上這篇Python利用splinter實(shí)現(xiàn)瀏覽器自動(dòng)化操作方法就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Pycharm安裝并配置jupyter notebook的實(shí)現(xiàn)
這篇文章主要介紹了Pycharm安裝并配置jupyter notebook的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-05-05python DataFrame轉(zhuǎn)dict字典過(guò)程詳解
這篇文章主要介紹了python DataFrame轉(zhuǎn)dict字典過(guò)程詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-12-12python算法與數(shù)據(jù)結(jié)構(gòu)之單鏈表的實(shí)現(xiàn)代碼
鏈表是一種物理存儲(chǔ)單元上非連續(xù)、非順序的存儲(chǔ)結(jié)構(gòu),數(shù)據(jù)元素的邏輯順序是通過(guò)鏈表中的指針鏈接次序?qū)崿F(xiàn)的。這篇文章主要介紹了python算法與數(shù)據(jù)結(jié)構(gòu)之單鏈表的實(shí)現(xiàn)代碼,需要的朋友可以參考下2019-06-06詳解Python中的內(nèi)建函數(shù),可迭代對(duì)象,迭代器
這篇文章主要介紹了Python內(nèi)建函數(shù),可迭代對(duì)象,迭代器,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04python使用flask與js進(jìn)行前后臺(tái)交互的例子
今天小編就為大家分享一篇python使用flask與js進(jìn)行前后臺(tái)交互的例子,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-07-07