溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Python如何實現(xiàn)網頁截圖功能

發(fā)布時間:2021-04-13 09:43:12 來源:億速云 閱讀:570 作者:小新 欄目:開發(fā)技術

這篇文章將為大家詳細講解有關Python如何實現(xiàn)網頁截圖功能,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

方法一、使用PyQt4的QtWebKit組件

#!/usr/bin/env python
# -*- coding: UTF-8 -*-
import sys
import os.path
from PyQt4 import QtGui,QtCore,QtWebKit
class PageShotter(QtGui.QWidget):
  def __init__(self,url,filename,parent=None):
    QtGui.QWidget.__init__(self,parent)
    self.url = url
    self.filename = filename
    self.webpage = None
  def shot(self):
    webview = QtWebKit.QWebView(self)
    webview.load(QtCore.QUrl(self.url))
    self.webpage = webview.page()
    self.connect(webview,QtCore.SIGNAL("loadFinished(bool)"),self.save_page)
  def save_page(self,finished):
    #print finished
    if finished:
      print u"開始截圖!"
      size = self.webpage.mainFrame().contentsSize()
      print u"頁面寬:%d,頁面高:%d" % (size.width(),size.height())
      self.webpage.setViewportSize(QtCore.QSize(size.width()+16,size.height()))
      img = QtGui.QImage(size, QtGui.QImage.Format_ARGB32)
      painter = QtGui.QPainter(img)
      self.webpage.mainFrame().render(painter)
      painter.end()
      filename= self.filename;
      if img.save(filename):
        filepath = os.path.join(os.path.dirname(__file__), filename)
        print u"截圖完畢:%s" % filepath
      else:
        print u"截圖失敗";
    else:
      print u"網頁加載失敗!"
    self.close()
if __name__=="__main__":
  app = QtGui.QApplication(sys.argv)
  shotter = PageShotter("https://www.jb51.net/", 'shot.png')
  shotter.shot()
  sys.exit(app.exec_())

運行后輸出:

QFont::setPixelSize: Pixel size <= 0 (0)
開始截圖!
頁面寬:1058,頁面高:9819
截圖完畢:C:\py\jb51PyDemo\src\Demo\shot.png

注:

Python2的32位操作系統(tǒng)安裝包可至此下載:https://www.jb51.net/softs/548192.html
64位操作系統(tǒng)下對應PyQt安裝包可至此下載:https://www.jb51.net/softs/548197.html)

Python3可直接使用pip命令安裝PyQt5庫,如:

pip3 install PyQt5-sip

方法二、使用selenium

#!/usr/bin/env python
# -*- coding: UTF-8 -*-
import time
from selenium import webdriver
browser = webdriver.Firefox()
browser.set_window_size(1055, 800)
browser.get("https://www.jb51.net/")
browser.find_element_by_id("idClose").click()
time.sleep(5)
browser.save_screenshot("shot.png")
browser.quit()

PS:selenium庫同樣可以使用pip命令安裝:

pip install selenium

另外,使用selenium時還需要下載geckodriver來驅動第三方瀏覽器,對于selenium3.x版本都會使用geckodriver來驅動firefox,所以需要下載geckodriver.exe,下載地址:https://github.com/mozilla/geckodriver/releases

下載后將geckodriver.exe放在C:\Python27即可(查看環(huán)境變量path中是否添加C:\Python27該路徑)

關于“Python如何實現(xiàn)網頁截圖功能”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經查實,將立刻刪除涉嫌侵權內容。

AI