python 三种方式实现截屏

导读本篇文章主要讲的是用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是比较简单的,但是不能指定获取程序的窗口,因此窗口也不能遮挡,不过可以指定截屏的位置www.linuxprobe.com

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)

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,您的第一个问题是如何使用Python OpenCV鼠标实现区域图。下面是代码示例: ``` import cv2 def draw_rectangle(event, x, y, flags, params): global x_init, y_init, drawing, top_left_pt, bottom_right_pt if event == cv2.EVENT_LBUTTONDOWN: drawing = True x_init, y_init = x, y elif event == cv2.EVENT_MOUSEMOVE: if drawing: top_left_pt, bottom_right_pt = (x_init, y_init), (x, y) cv2.rectangle(image, top_left_pt, bottom_right_pt, (0, 255, 0), 2) elif event == cv2.EVENT_LBUTTONUP: drawing = False top_left_pt, bottom_right_pt = (x_init, y_init), (x, y) cv2.rectangle(image, top_left_pt, bottom_right_pt, (0, 255, 0), 2) roi = image[top_left_pt[1]:bottom_right_pt[1], top_left_pt[0]:bottom_right_pt[0]] cv2.imshow("Region of Interest", roi) cv2.imwrite('roi.jpg', roi) drawing = False top_left_pt, bottom_right_pt = (-1, -1), (-1, -1) image = cv2.imread("image.jpg") cv2.namedWindow("Window") cv2.setMouseCallback("Window", draw_rectangle) while True: cv2.imshow("Window", image) key = cv2.waitKey(1) if key == 27: break cv2.destroyAllWindows() ``` 使用上述代码,您可以在Python OpenCV中创建一个名为"Window"的窗口,并在其中实现鼠标绘制矩形框来选择感兴趣的区域,并将其保存为图像文件。具体实现方式为在窗口上设置一个鼠标回调函数,当用户点击左键时开始绘制矩形框,当用户拖动鼠标时更新矩形框的位置,当用户释放左键时结束绘制矩形框并提取对应的区域图像。最后,您可以通过按下ESC键来退出程序。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值