Python 實(shí)現(xiàn)網(wǎng)頁自動(dòng)截圖的示例講解
背景介紹
最近在為部門編寫一個(gè)自動(dòng)化測(cè)試工具,工具涉及到一個(gè)功能,即 將自動(dòng)化測(cè)試生成的html報(bào)告截圖,作為郵件正文,html文件上傳到web服務(wù)器以鏈接形式添加到郵件中,最后發(fā)送郵件。
任務(wù)難點(diǎn)
之前從未接觸過頁面自動(dòng)截圖相關(guān)的方面,因此如何自動(dòng)進(jìn)行頁面截圖成為本地調(diào)研方向。
方案思考
在剛接到這個(gè)任務(wù)時(shí),并不認(rèn)同目前的方案。曾經(jīng)一度認(rèn)為,將html報(bào)告的內(nèi)容寫入郵件正文,即可通過html的形式發(fā)送郵件了。經(jīng)過嘗試后發(fā)現(xiàn),郵件不支持帶javascript的html。因此,選擇了預(yù)覽html并自動(dòng)截圖的方案。
編程語言
python 2.7
使用方案 :
selenium + phantomjs
方案介紹
實(shí)現(xiàn)自動(dòng)預(yù)覽html并截圖有以下幾個(gè)步驟:
1. 瀏覽器打開html
2. 對(duì)瀏覽器頁面進(jìn)行截圖
3. 將截圖保存到指定位置
最初,筆者使用了這個(gè)實(shí)現(xiàn)方案:
(1).使用webbrowser 庫(kù)打開默認(rèn)瀏覽器,顯示url

(2).使用PIL.ImageGrab庫(kù)的對(duì)屏幕進(jìn)行進(jìn)行截圖

到此為止,筆者已經(jīng)獲得html的預(yù)覽截圖,一切似乎很順利,但接下來
發(fā)現(xiàn)了以下幾個(gè)問題:
(1).打開默認(rèn)瀏覽器時(shí),默認(rèn)瀏覽器是什么,瀏覽器處于什么狀態(tài)都不知曉。
(2).瀏覽器顯示html,會(huì)有一個(gè)顯示的打開瀏覽器,瀏覽器打開html的動(dòng)作出現(xiàn),如果用戶此時(shí)產(chǎn)生了其他動(dòng)作,必定會(huì)對(duì)之后的截圖產(chǎn)生影響。
(3).屏幕截圖,將整個(gè)屏幕都進(jìn)行截圖,截圖中除了html頁面正文,同時(shí)也包含了瀏覽器等當(dāng)前屏幕包含的所有元素,暴漏了用戶隱私。
(4).如果頁面較大,頁面會(huì)產(chǎn)生上下翻頁的效果,屏幕截圖無法應(yīng)對(duì)此種頁面,截圖看到的報(bào)告只有一部分。
基于上述問題,筆者放棄了這個(gè)看起來簡(jiǎn)單有效的方案。從而
對(duì)方案挖掘了一些深層需求:
(1).打開瀏覽器必須隱式調(diào)用,用戶無法看到工具在做什么,從而不會(huì)通過誤操作對(duì)工具產(chǎn)生影響。
(2).截圖必須針對(duì)瀏覽器頁面正文 ,保證無其他冗余信息,且截到頁面全圖根據(jù)這些需求,筆者經(jīng)過一系列嘗試終于發(fā)現(xiàn)了selenium + phantomjs。
python selenium : 是python對(duì)瀏覽器自動(dòng)化測(cè)試框架selenium的擴(kuò)展,selenium庫(kù)支持了selenium所包含大部分功能。
phantomjs : 是一個(gè)無界面的,可腳本編程的webkit瀏覽器,python selenium同樣提供對(duì)phantomjs的支持。
接下來一切就很容易了:
(1).安裝python selenium 庫(kù),推薦使用pip快速安裝最新版本
(2).下載phantomjs.exe,將其添加到環(huán)境變量 path 中 。方便起見可以直接放在python的安裝目錄根目錄下
(3).編寫測(cè)試代碼

簡(jiǎn)單講解一下代碼:
fromselenium importwebdriver #從selenium庫(kù)導(dǎo)入webdirver brower=webdriver.PhantomJS() #使用webdirver.PhantomJS()方法新建一個(gè)phantomjs的對(duì)象,這里會(huì)使用到phantomjs.exe,環(huán)境變量path中找不到phantomjs.exe,則會(huì)報(bào)錯(cuò) brower.get(url) #使用get()方法,打開指定頁面。注意這里是phantomjs是無界面的,所以不會(huì)有任何頁面顯示 brower.maximize_window() #設(shè)置phantomjs瀏覽器全屏顯示 brower.save_screenshot(picName) #使用save_screenshot將瀏覽器正文部分截圖,即使正文本分無法一頁顯示完全,save_screenshot也可以完全截圖 brower.close() #關(guān)閉phantomjs瀏覽器,不要忽略了這一步,否則你會(huì)在任務(wù)瀏覽器中發(fā)現(xiàn)許多phantomjs進(jìn)程
執(zhí)行了上述代碼后,我們看一下截圖效果吧:

以上這篇Python 實(shí)現(xiàn)網(wǎng)頁自動(dòng)截圖的示例講解就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
2025最新版Python3.13.1安裝使用指南(超詳細(xì))
Python編程語言自誕生以來,已經(jīng)成為全球最受歡迎的編程語言之一,它簡(jiǎn)單易學(xué)易用,以標(biāo)準(zhǔn)庫(kù)和功能強(qiáng)大且廣泛外 掛的擴(kuò)展庫(kù),為用戶提供包羅萬象、強(qiáng)大全面的功能,此次給大家介紹了2025年最新版Python 3.13.1安裝使用指南全面更新,需要的朋友可以參考下2025-03-03
使用Python自建輕量級(jí)的HTTP調(diào)試工具
這篇文章主要為大家詳細(xì)介紹了如何使用Python自建一個(gè)輕量級(jí)的HTTP調(diào)試工具,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以參考一下2025-04-04
Python判斷兩個(gè)list是否是父子集關(guān)系的實(shí)例
今天小編就為大家分享一篇Python判斷兩個(gè)list是否是父子集關(guān)系的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-05-05
人工智能深度學(xué)習(xí)OpenAI?baselines的使用方法
這篇文章主要為大家介紹了人工智能深度學(xué)習(xí)OpenAI?baselines的使用方法,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-05-05
python庫(kù)matplotlib繪制坐標(biāo)圖
這篇文章主要為大家介紹了python庫(kù)matplotlib繪制坐標(biāo)圖,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-10-10
Python中實(shí)現(xiàn)限定抽獎(jiǎng)次數(shù)的機(jī)制的項(xiàng)目實(shí)踐
抽獎(jiǎng)系統(tǒng)作為吸引用戶、提高用戶參與度和活躍度的重要手段,本文主要介紹了Python中實(shí)現(xiàn)限定抽獎(jiǎng)次數(shù)的機(jī)制的項(xiàng)目實(shí)踐,具有一定的參考價(jià)值,感興趣的可以了解一下2024-05-05
Python自動(dòng)調(diào)用IE打開某個(gè)網(wǎng)站的方法
這篇文章主要介紹了Python自動(dòng)調(diào)用IE打開某個(gè)網(wǎng)站的方法,涉及Python調(diào)用系統(tǒng)win32組件的相關(guān)技巧,需要的朋友可以參考下2015-06-06

