スクリーンショットを取得するための Python の 3 つの方法 [詳細 + 完全なコード]

人生は短すぎるので私はPythonを使っています

Pythonでスクリーンショットを実現するにはどうすればよいですか?

ここに画像の説明を挿入

1. 方法 1

PIL の ImageGrab モジュール

PIL で ImageGrab モジュールを使用するのは簡単ですが、少し非効率的です

PIL は Python イメージング ライブラリであり、
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)#python学习交流:903971231#
cv2.imwrite('screenshot1.jpg', img)
# img = Image.fromarray(img)
# img.save('screenshot1.jpg')

2.方法2

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)})
#python学习交流:903971231#
 
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")

3. 方法 3

pyautogui は比較的単純ですが、

ただし、プログラムを取得するウィンドウを指定することはできません。

そのため、窓を塞ぐことはできず、

ただし、スクリーンショットの場所を指定することはできます

import pyautogui
import cv2  # https://www.lfd.uci.edu/~gohlke/pythonlibs/#opencv
import numpy as np
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)

ここに画像の説明を挿入
ここに画像の説明を挿入

おすすめ

転載: blog.csdn.net/xff123456_/article/details/128501167