Python 截屏 程序

用 Python PIL 简单实现截屏

 

# -*- coding: cp936 -*-
"""
Description: 在Windows上截屏的小程序。使用Python的PIL库
"""
from PIL import ImageGrab
import os

im = ImageGrab.grab()
# or call im.show() to view the image directly
im.save("c:/screenshot.png")#保存图片
os.execvp( "mspaint",('mspaint','c:/screenshot.png'))#调用画图程序打开截屏图片

 

#-----------------------------------------------------------------------------------------------------

 

# -*- coding:UTF-8 -*- 
''' 
import os 
from PIL import ImageGrab 
import time 
 
class Capturer(object): 
     
    '''截屏程序'''     
    def capture(self,path='C://images'): 
        ''' 
                    截屏并保存图片至path目录下 
        ''' 
        if not os.path.isdir(path) or not os.path.exists(path): 
            os.makedirs(path) 
        cutime = time.strftime('%Y%m%d%H%M%S',time.localtime(time.time())) 
        filename = path+'//'+cutime+'.gif' 
 
        im = ImageGrab.grab() 
        im.save(filename) 
 
if __name__ == '__main__': 
     
    cer = Capturer() 
    while True: 
        time.sleep(2) 
        cer.capture() 

 

#-----------------------------------------------------------------------------------------------------

# -*- coding: cp936 -*- 
import time,Image 
import os, win32gui, win32ui, win32con, win32api 
  
def window_capture(dpath): 
    '''''
截屏函数,调用方法window_capture('d://') ,参数为指定保存的目录
返回图片文件名,文件名格式:日期.jpg 如:2009328224853.jpg
    ''' 
    hwnd = 0 
    hwndDC = win32gui.GetWindowDC(hwnd)  
    mfcDC=win32ui.CreateDCFromHandle(hwndDC)  
    saveDC=mfcDC.CreateCompatibleDC()  
    saveBitMap = win32ui.CreateBitmap()  
    MoniterDev=win32api.EnumDisplayMonitors(None,None) 
    w = MoniterDev[0][2][2] 
    h = MoniterDev[0][2][3] 
    #print w,h   #图片大小 
    saveBitMap.CreateCompatibleBitmap(mfcDC, w, h)  
    saveDC.SelectObject(saveBitMap)  
    saveDC.BitBlt((0,0),(w, h) , mfcDC, (0,0), win32con.SRCCOPY) 
    cc=time.gmtime() 
    bmpname=str(cc[0])+str(cc[1])+str(cc[2])+str(cc[3]+8)+str(cc[4])+str(cc[5])+'.bmp' 
    saveBitMap.SaveBitmapFile(saveDC, bmpname) 
    Image.open(bmpname).save(bmpname[:-4]+".jpg") 
    os.remove(bmpname) 
    jpgname=bmpname[:-4]+'.jpg' 
    djpgname=dpath+jpgname 
    copy_command = "move %s %s" % (jpgname, djpgname) 
    os.popen(copy_command) 
    return bmpname[:-4]+'.jpg' 
  
#调用截屏函数     
window_capture('d://')

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个使用Python编写的截图程序,它可以让你选择截图区域并保存截图到本地: ```python import tkinter as tk from PIL import ImageGrab class Screenshot: def __init__(self): self.root = tk.Tk() self.root.title("截图程序") self.root.attributes('-alpha', 0.5) self.root.attributes('-topmost', True) self.root.geometry('200x200') self.start_x = self.start_y = self.end_x = self.end_y = 0 self.canvas = tk.Canvas(self.root, bg='white', width=200, height=200) self.canvas.pack(expand=True, fill='both') self.canvas.bind("<ButtonPress-1>", self.on_button_press) self.canvas.bind("<B1-Motion>", self.on_move_press) self.canvas.bind("<ButtonRelease-1>", self.on_button_release) self.root.mainloop() def on_button_press(self, event): self.start_x = self.root.winfo_pointerx() self.start_y = self.root.winfo_pointery() self.end_x = self.start_x self.end_y = self.start_y def on_move_press(self, event): self.end_x = self.root.winfo_pointerx() self.end_y = self.root.winfo_pointery() self.canvas.delete("rect") self.canvas.create_rectangle(self.start_x, self.start_y, self.end_x, self.end_y, outline='red', tags="rect") def on_button_release(self, event): box = (min(self.start_x, self.end_x), min(self.start_y, self.end_y), max(self.start_x, self.end_x), max(self.start_y, self.end_y)) screenshot = ImageGrab.grab(bbox=box) screenshot.save("screenshot.png") self.root.destroy() if __name__ == '__main__': Screenshot() ``` 该程序使用了Python的Tkinter和Pillow库。运行程序后,你可以使用鼠标选择需要截图的区域,截图将保存在当前目录下的`screenshot.png`文件中。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值