Python实现屏幕截图的两种方式
- 使用windowsAPI
- 使用PIL中的ImageGrab模块
下面对两者的特点和用法进行详细解释。
一、Python调用windowsAPI实现屏幕截图
好处是
- 灵活
- 速度快
缺点是:
- 写法繁琐
- 不跨平台
importtime importwin32gui,win32ui,win32con,win32api defwindow_capture(filename): hwnd=0#窗口的编号,0号表示当前活跃窗口 #根据窗口句柄获取窗口的设备上下文DC(DiviceContext) hwndDC=win32gui.GetWindowDC(hwnd) #根据窗口的DC获取mfcDC mfcDC=win32ui.CreateDCFromHandle(hwndDC) #mfcDC创建可兼容的DC saveDC=mfcDC.CreateCompatibleDC() #创建bigmap准备保存图片 saveBitMap=win32ui.CreateBitmap() #获取监控器信息 MoniterDev=win32api.EnumDisplayMonitors(None,None) w=MoniterDev[0][2][2] h=MoniterDev[0][2][3] #printw,h#图片大小 #为bitmap开辟空间 saveBitMap.CreateCompatibleBitmap(mfcDC,w,h) #高度saveDC,将截图保存到saveBitmap中 saveDC.SelectObject(saveBitMap) #截取从左上角(0,0)长宽为(w,h)的图片 saveDC.BitBlt((0,0),(w,h),mfcDC,(0,0),win32con.SRCCOPY) saveBitMap.SaveBitmapFile(saveDC,filename) beg=time.time() foriinrange(10): window_capture("haha.jpg") end=time.time() print(end-beg)
输出结果为0.375秒,也就是说通过windowsAPI每次截图只需要0.0375s,真是快得一逼呀。
二、使用PIL的ImageGrab模块
importtime importnumpyasnp fromPILimportImageGrab #每抓取一次屏幕需要的时间约为1s,如果图像尺寸小一些效率就会高一些 beg=time.time() debug=False foriinrange(10): img=ImageGrab.grab(bbox=(250,161,1141,610)) img=np.array(img.getdata(),np.uint8).reshape(img.size[1],img.size[0],3) end=time.time() print(end-beg)
输出结果为4.015秒,也就是说截取一次屏幕需要半秒钟,更何况此处只截取了窗口的一部分矩形区域。所以ImageGrab模块能用是能用,就是有点慢。
三、使用Selenium截图
使用Selenium只能进行WEB程序截图
使用Selenium的各个浏览器需要制定驱动的位置,驱动下载地址参见Selenium官网
fromseleniumimportwebdriver importtime defcapture(url,filename="capture.png"): browser=webdriver.Chrome(r"C:\Users\weidiao\Desktop\chromedriver_win32\chromedriver.exe") browser.set_window_size(1200,900) browser.get(url)#Loadpage browser.execute_script(""" (function(){ vary=0; varstep=100; window.scroll(0,0); functionf(){ if(y打印时间为3.033s,速度介于windowsAPI和PILImageGrab模块之间。
ps:下面看下python基础===python实现截图
python实现全屏截图:
fromPILimportImageGrab im=ImageGrab.grab() im.save('F:\\12.png')总结
以上所述是小编给大家介绍的Python实现屏幕截图的两种方式,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对毛票票网站的支持!