共计 1736 个字符,预计需要花费 5 分钟才能阅读完成。
导读 | 本篇文章主要讲的是用 Python 实现屏幕截图详解,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下 |
一、方法一
PIL 中的 ImageGrab 模块
使用 PIL 中的 ImageGrab 模块简单,但是效率有点低
PIL 是 Python Imaging Library,它为 python 解释器提供图像编辑函数能力。ImageGrab 模块可用于将屏幕或剪贴板的内容复制到 PIL 图像存储器中。
PIL.ImageGrab.grab() 方法拍摄屏幕快照。边框内的像素在 Windows 上以“RGB”图像的形式返回,在 macOS 上以“RGBA”的形式返回。
如果省略了边界框,则会复制整个屏幕。
import numpy as np | |
from PIL import ImageGrab, Image | |
import cv2 | |
img = ImageGrab.grab(bbox=(0, 0, 1920, 1080)) # bbox 定义左、上、右和下像素的 4 元组 | |
print(img.size[1], img.size[0]) | |
img = np.array(img.getdata(), np.uint8).reshape(img.size[1], img.size[0], 3) | |
print(img) | |
cv2.imwrite('screenshot1.jpg', img) | |
# img = Image.fromarray(img) | |
# img.save('screenshot1.jpg') |
二、方法二
PyQt 比调用 windows API 简单很多,而且有 windows API 的很多优势,比如速度快,可以指定获取的窗口,即使窗口被遮挡。
需注意的是,窗口最小化时无法获取截图。
首先需要获取窗口的句柄。
import win32gui | |
from PyQt5.QtWidgets import QApplication | |
import sys | |
hwnd_title = dict() | |
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) | |
# print(hwnd_title.items()) | |
for h, t in hwnd_title.items(): | |
if t != "": | |
print(h, t) | |
# 程序会打印窗口的 hwnd 和 title,有了 title 就可以进行截图了。hwnd = win32gui.FindWindow(None, 'C:\Windows\system32\cmd.exe') | |
app = QApplication(sys.argv) | |
screen = QApplication.primaryScreen() | |
img = screen.grabWindow(hwnd).toImage() | |
img.save("screenshot2.jpg") |
三、方法三
pyautogui 是比较简单的,但是不能指定获取程序的窗口,因此窗口也不能遮挡,不过可以指定截屏的位置
import pyautogui | |
import cv2 # https://www.lfd.uci.edu/~gohlke/pythonlibs/#opencv | |
import numpy as nppy | |
from PIL import Image | |
img = pyautogui.screenshot(region=[0, 0, 1920, 1080]) # x,y,w,h | |
# img = Image.fromarray(np.uint8(img)) | |
# img.save('screenshot3.png') | |
img = cv2.cvtColor(np.asarray(img), cv2.COLOR_RGB2BGR) # cvtColor 用于在图像中不同的色彩空间进行转换, 用于后续处理。cv2.imwrite('screenshot3.jpg', img) |
正文完
星哥玩云-微信公众号
