您好,登錄后才能下訂單哦!
這篇文章主要介紹python實現截圖功能的方法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!
在python中,可以通過調用windows API或者使用PIL中的ImageGrab模塊來實現截圖功能。方法是:1、利用BitBlt設置截取圖片的尺寸;2、利用saveBitMap對截取的圖像進行保存。
一、Python調用windows API實現屏幕截圖
好處是
靈活
速度快
缺點是:
寫法繁瑣
不跨平臺
import time import win32gui, win32ui, win32con, win32api def window_capture(filename): hwnd = 0 # 窗口的編號,0號表示當前活躍窗口 # 根據窗口句柄獲取窗口的設備上下文DC(Divice Context) hwndDC = win32gui.GetWindowDC(hwnd) # 根據窗口的DC獲取mfcDC mfcDC = win32ui.CreateDCFromHandle(hwndDC) # mfcDC創建可兼容的DC saveDC = mfcDC.CreateCompatibleDC() # 創建bigmap準備保存圖片 saveBitMap = win32ui.CreateBitmap() # 獲取監控器信息 MoniterDev = win32api.EnumDisplayMonitors(None, None) w = MoniterDev[0][2][2] h = MoniterDev[0][2][3] # print w,h #圖片大小 # 為bitmap開辟空間 saveBitMap.CreateCompatibleBitmap(mfcDC, w, h) # 高度saveDC,將截圖保存到saveBitmap中 saveDC.SelectObject(saveBitMap) # 截取從左上角(0,0)長寬為(w,h)的圖片 saveDC.BitBlt((0, 0), (w, h), mfcDC, (0, 0), win32con.SRCCOPY) saveBitMap.SaveBitmapFile(saveDC, filename) beg = time.time() for i in range(10): window_capture("haha.jpg") end = time.time() print(end - beg)
輸出結果為0.375秒,也就是說通過windows API每次截圖只需要0.0375s,真是快呀。
二、使用PIL的ImageGrab模塊
import time import numpy as np from PIL import ImageGrab # 每抓取一次屏幕需要的時間約為1s,如果圖像尺寸小一些效率就會高一些 beg = time.time() debug = False for i in range(10): img = ImageGrab.grab(bbox=(250, 161, 1141, 610)) img = np.array(img.getdata(), np.uint8).reshape(img.size[1], img.size[0], 3) end = time.time() print(end - beg)
輸出結果為4.015秒,也就是說截取一次屏幕需要半秒鐘,更何況此處只截取了窗口的一部分矩形區域。所以ImageGrab模塊能用是能用,就是有點慢。
以上是python實現截圖功能的方法的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。