用Python實現(xiàn)屏幕截圖詳解
一、序言
在csdn上有很多純copy,這給我復(fù)現(xiàn)帶來了很大的麻煩,所以我想根據(jù)我的個人找截圖的經(jīng)歷記錄下來,給未來的自己看,免得忘記了云云。
由于我比較喜歡用opencv處理圖像,所以截屏最后都會附帶一個使用opencv顯示圖片的一個步驟。
二、環(huán)境配置
1、下載pyautogui包
pip install pyautogui -i https://pypi.tuna.tsinghua.edu.cn/simple/
注:使用pyautogui方法獲取截屏的話,只下載這個就行了
2、下載opencv-python包
pip install opencv-python -i https://pypi.tuna.tsinghua.edu.cn/simple/
注:方便實現(xiàn)對圖片的進一步處理,比如實時獲取云云。
3、下載PyQt5包
pip install PyQt5 -i https://pypi.tuna.tsinghua.edu.cn/simple/
注:使用PyQt方法截屏下載介個
4、下載pypiwin32包
pip install pypiwin32 -i https://pypi.tuna.tsinghua.edu.cn/simple/
注:使用PyQt方法截屏下載介個
三、屏幕截屏源碼與解析
1、使用pyautogui方法實現(xiàn)截屏
import pyautogui
import cv2
import numpy as np
img = pyautogui.screenshot(region=[300,50, 200, 100]) # 分別代表:左上角坐標(biāo),寬高
#對獲取的圖片轉(zhuǎn)換成二維矩陣形式,后再將RGB轉(zhuǎn)成BGR
#因為imshow,默認通道順序是BGR,而pyautogui默認是RGB所以要轉(zhuǎn)換一下,不然會有點問題
img = cv2.cvtColor(np.asarray(img), cv2.COLOR_RGB2BGR)
cv2.imshow("截屏",img)
cv2.waitKey(0)
優(yōu)點:
方便快捷,容易寫核心部分就一行.速度快0.04s左右,基本可以達到實時截屏的效果。可以自由確定截屏區(qū)域
缺點:
但是不能指定獲取程序的窗口,因此窗口也不能遮擋。 2、使用PyQt方法實現(xiàn)截屏 a.獲取窗口的句柄,也就是目標(biāo)窗口名title。
import win32gui
hwnd_title = dict() #創(chuàng)建字典保存窗口的句柄與名稱映射關(guān)系
def get_all_hwnd(hwnd, mouse):
if win32gui.IsWindow(hwnd) and win32gui.IsWindowEnabled(hwnd) and win32gui.IsWindowVisible(hwnd):
hwnd_title.update({hwnd: win32gui.GetWindowText(hwnd)})
win32gui.EnumWindows(get_all_hwnd, 0)
for h, t in hwnd_title.items():
if t!= "":
print(h, t)
注:程序會打印所有窗口的hwnd和title,有了title就可以進行截圖了。
b.使用PyQt5截屏核心程序
from PyQt5.QtWidgets import QApplication
import win32gui
import sys
#這個是截取全屏的
hwnd = win32gui.FindWindow(None, 'C:/Windows/system32/cmd.exe')
app = QApplication(sys.argv)
screen = QApplication.primaryScreen()
img = screen.grabWindow(hwnd).toImage()
img.save("screenshot.jpg")
注:如果想截取特定的窗口,只需要將C:/Windows/system32/cmd.exe換成上一個程序中打印的title,并且保證那個窗口沒有被你最小化即可
優(yōu)點:
方便快捷,容易寫核心部分就一行.速度快0.04s左右,基本可以達到實時截屏的效果??梢宰杂纱_定要截屏的窗口
缺點:
不可以自由確定截屏區(qū)域 c.使用PyQt5截屏用Mat格式顯示的核心程序
def convertQImageToMat(incomingImage):
''' Converts a QImage into an opencv MAT format '''
# Format_RGB32 = 4,存入格式為B,G,R,A 對應(yīng) 0,1,2,3
# RGB32圖像每個像素用32比特位表示,占4個字節(jié),
# R,G,B分量分別用8個bit表示,存儲順序為B,G,R,最后8個字節(jié)保留
incomingImage = incomingImage.convertToFormat(4)
width = incomingImage.width()
height = incomingImage.height()
ptr = incomingImage.bits()
ptr.setsize(incomingImage.byteCount())
arr = np.array(ptr).reshape(height, width, 4) # Copies the data
# arr為BGRA,4通道圖片
return arr
from PyQt5.QtWidgets import QApplication
import win32gui
import sys
import cv2
import numpy as np
hwnd = win32gui.FindWindow(None, '劍士之魂中文版小游戲,在線玩,4399小游戲 - 360安全瀏覽器 13.1')
app = QApplication(sys.argv)
screen = QApplication.primaryScreen()
img = screen.grabWindow(hwnd).toImage()
img=convertQImageToMat(img)#將獲取的圖像從QImage轉(zhuǎn)換為RBG格式
cv2.imshow("asd",img) #imshow
cv2.waitKey(0)
四、結(jié)語
我再查詢了多個截屏的方法之后,發(fā)現(xiàn)就學(xué)會這兩種截屏方法即可,所以就沒有再放其他方法了
到此這篇關(guān)于用Python實現(xiàn)屏幕截圖詳解的文章就介紹到這了,更多相關(guān)Python屏幕截圖內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python利用 SVM 算法實現(xiàn)識別手寫數(shù)字
支持向量機 (Support Vector Machine, SVM) 是一種監(jiān)督學(xué)習(xí)技術(shù),它通過根據(jù)指定的類對訓(xùn)練數(shù)據(jù)進行最佳分離,從而在高維空間中構(gòu)建一個或一組超平面。本文將介紹通過SVM算法實現(xiàn)手寫數(shù)字的識別,需要的可以了解一下2021-12-12
使用Python模塊進行數(shù)據(jù)處理的詳細步驟
Python 提供了豐富的模塊和庫,用于處理各種類型的數(shù)據(jù),本文介紹了一些常用的模塊和庫,以及如何使用它們進行數(shù)據(jù)處理的詳細步驟和代碼示例,對我們的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下2025-02-02

