溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

使用Python自動(dòng)控制windows桌面的案例

發(fā)布時(shí)間:2021-02-04 13:51:41 來源:億速云 閱讀:666 作者:小新 欄目:開發(fā)技術(shù)

這篇文章給大家分享的是有關(guān)使用Python自動(dòng)控制windows桌面的案例的內(nèi)容。小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨小編過來看看吧。

前言

在使用PC時(shí)與PC交互的主要途徑是看屏幕顯示、聽聲音,點(diǎn)擊鼠標(biāo)和敲鍵盤等等。在自動(dòng)化辦公的趨勢下,繁瑣的工作可以讓程序自動(dòng)完成。比如自動(dòng)化測試、自動(dòng)下單交易等。很多軟件除了可以GUI方式操作外還可以用CLI接口操作,不過當(dāng)一些軟件未提供CLI接口時(shí),我們應(yīng)該怎么辦呢?我們還可以用程序控制桌面上的窗口、模擬點(diǎn)擊鼠標(biāo)或按下鍵盤等動(dòng)作來釋放自己。

pywin32是一個(gè)Python庫,它為Python提供訪問Windows API的擴(kuò)展,提供了齊全的windows常量、接口、線程以及COM機(jī)制等等,安裝后會(huì)自帶一個(gè)pythonwin的IDE。接下來主要介紹下如何通過Python去操作windows桌面軟件。

1、打開軟件或文件

比如打開一個(gè)谷歌瀏覽器,或者打開一個(gè)word文件,如下所示:

win32api.ShellExecute(1, 'open',
 r'C:Program Files (x86)GoogleChromeApplicationchrome.exe',
 '', '', 1)
win32api.ShellExecute(1, 'open',
 r'C:UsersJayDesktopEnvironment Guider.docx',
 '', '', 1)

win32api.ShellExecute()的參數(shù)主要包括:

  • HWND:指定父窗口句柄

  • Operation:指定動(dòng)作, 譬如"edit",“explore”,“open”,“find”,“print”,“NULL”

  • FileName:指定要打開的文件或程序

  • Parameters:指定打開程序所需參數(shù)

  • Directory:缺省目錄

  • ShowCmd:打開選項(xiàng),可選值:

    • SW_HIDE = 0; {隱藏窗口,活動(dòng)狀態(tài)給令一個(gè)窗口}

    • SW_SHOWNORMAL = 1; {用最近的大小和位置顯示窗口, 同時(shí)令其進(jìn)入活動(dòng)狀態(tài)}

    • SW_NORMAL = 1; {用當(dāng)前的大小和位置顯示一個(gè)窗口,不改變活動(dòng)窗口}

    • SW_SHOWMINIMIZED = 2; {最小化窗口,并將其激活}

    • SW_SHOWMAXIMIZED = 3; {最大化窗口,并將其激活}

    • SW_MAXIMIZE = 3; {同 SW_SHOWMAXIMIZED}

    • SW_SHOWNOACTIVATE = 4; {用最近的大小和位置顯示一個(gè)窗口,不改變活動(dòng)窗口}

    • SW_SHOW = 5; {用當(dāng)前的大小和位置顯示一個(gè)窗口,令其進(jìn)入活動(dòng)狀態(tài)}

    • SW_MINIMIZE = 6; {最小化窗口, 不激活}

    • SW_SHOWMINNOACTIVE = 7; {同 SW_MINIMIZE}

    • SW_SHOWNA = 8; {用當(dāng)前的大小和位置顯示一個(gè)窗口,不改變活動(dòng)窗口}

    • SW_RESTORE = 9; {同 SW_SHOWNORMAL}

    • SW_SHOWDEFAULT = 10; {同 SW_SHOWNORMAL}

    • SW_MAX = 10; {同 SW_SHOWNORMAL}

執(zhí)行成功會(huì)返回應(yīng)用程序句柄, 如果返回值 <= 32,則表示執(zhí)行錯(cuò)誤。返回值可能的錯(cuò)誤有:

  • 0—— {內(nèi)存不足}

  • 2—— {文件名錯(cuò)誤}

  • 3—— {路徑名錯(cuò)誤}

  • 11—— {EXE 文件無效}

  • 26—— {發(fā)生共享錯(cuò)誤}

  • 27—— {文件名不完全或無效}

  • 28—— {超時(shí)}

  • 29—— {DDE 事務(wù)失敗}

  • 30—— {正在處理其他 DDE 事務(wù)而不能完成該 DDE 事務(wù)}

  • 31—— {沒有相關(guān)聯(lián)的應(yīng)用程序}

2、查找窗體的句柄

在win32編程的世界里,包括窗口到文本框的所有控件都是窗體,所有的窗體都有獨(dú)立的句柄。要操作任意一個(gè)窗體,都需要找到這個(gè)窗體的句柄。句柄是一個(gè)32位整數(shù),在windows中用于標(biāo)記對(duì)象。比如查找Snipping Tool和New Text Document.txt的句柄,如下所示:

para_hld = win32gui.FindWindow(None, "Snipping Tool")# 1836416
para_hld = win32gui.FindWindow(None, "New Text Document.txt - Notepad")# 591410

win32gui.FindWindow()屬于win32gui的模塊,它自頂層窗口(也就是桌面)開始搜索條件匹配的窗體,并返回這個(gè)窗體的句柄。該函數(shù)僅能查找主窗口,因此無法搜索子窗口,也不區(qū)分大小寫,未找到則返回0。

win32gui.FindWindow()的參數(shù)主要包括 (lpClassName=None, lpWindowName=None):

  • lpClassName:字符型,窗體的類名,可以在Spy++里找到

  • lpWindowName:字符型,窗口名,也就是標(biāo)題欄上能看見的那個(gè)標(biāo)題。

使用Python自動(dòng)控制windows桌面的案例

3、查找句柄的類名和標(biāo)題

比如通過Snipping Tool和New Text Document.txt的句柄查找對(duì)應(yīng)的類名和標(biāo)題,如下所示:

title = win32gui.GetWindowText(1836416)
classname = win32gui.GetClassName(1836416)
print "windows handler:{0}; title:{1}; classname:{2}".format(1836416, title, classname)

打印顯示如下:

windows handler:1836416; title:Snipping Tool; classname:Microsoft-Windows-Tablet-SnipperToolbar
title = win32gui.GetWindowText(591410)
classname = win32gui.GetClassName(591410)
print "windows handler:{0}; title:{1}; classname:{2}".format(591410, title, classname)

打印顯示如下:

windows handler:591410; title:New Text Document.txt - Notepad; classname:Notepad

4、調(diào)用win32gui.EnumWindows()枚舉所有窗口句柄

直到最后一個(gè)頂層窗口被枚舉則停止枚舉過程。如下所示:

hWndList = []
win32gui.EnumWindows(lambda hWnd, param: param.append(hWnd), hWndList)
print hWndList
for hwnd in hWndList:
 title = win32gui.GetWindowText(hwnd)
 print title

打印顯示如下:

[852802L, 65946L, 65928L, 65930L, 65900L, 65920L, 65924L, 65922L, 65944L, 65892L, 65886L, 6817870L, 65960L, 6031410L, …… 66052L, 65734L]
……
New Text Document.txt - Notepad
Snipping Tool
DDE Server Window
OfficePowerManagerWindow
OfficePowerManagerWindow
DDE Server Window
GDI+ Window
Global Internet Access
……

5、win32gui.SetForegroundWindow()函數(shù)將指定窗體設(shè)置到最頂層,并且激活該窗口

構(gòu)造函數(shù)為:win32gui.SetWindowPos(HWN hWnd,HWND hWndlnsertAfter, int X,int Y, int cx,int cy, UNIT.Flags)

關(guān)于win32gui.SetForegroundWindow(para_hld)報(bào)錯(cuò)的問題:

pywintypes.error: (0, ‘SetForegroundWindow', ‘No error message is available')

其實(shí)調(diào)用SetForegroundWindow()會(huì)有很多限制,參考官網(wǎng)的說明

使用Python自動(dòng)控制windows桌面的案例

因此調(diào)用SetForegroundWindow()時(shí)需要查看當(dāng)前運(yùn)行的條件是否符合上述要求,此處在調(diào)用SetForegroundWindow()前事先發(fā)送一個(gè)鍵盤event來解決該問題。

例程如下所示:

win32api.keybd_event(13, 0, 0, 0) #
win32gui.SetForegroundWindow(para_hld)

6、win32api.keybd_event()模擬鍵盤輸入

構(gòu)造函數(shù)如下所示:

win32api.keybd_event (bVk, bScan, dwFlags, dwExtraInfo)
  • bVk:虛擬鍵碼(鍵盤鍵碼對(duì)照表見附錄);

  • bScan:硬件掃描碼,一般設(shè)置為0即可;

  • dwFlags:函數(shù)操作的一個(gè)標(biāo)志位,如果值為KEYEVENTF_EXTENDEDKEY則該鍵被按下,也可設(shè)置為0即可,如果值為KEYEVENTF_KEYUP則該按鍵被釋放;

  • dwExtraInfo:定義與擊鍵相關(guān)的附加的32位值,一般設(shè)置為0即可。

按下enter鍵后抬起的例程如下所示:

win32api.keybd_event(13,0,0,0) # enter
win32api.keybd_event(13,0,win32con.KEYEVENTF_KEYUP,0) #釋放按鍵

7、模擬鼠標(biāo)輸入

直接給出例程,如下所示:

# 獲取鼠標(biāo)當(dāng)前位置的坐標(biāo)
print win32api.GetCursorPos()
# 將鼠標(biāo)移動(dòng)到坐標(biāo)處
win32api.SetCursorPos((100, 100))
# 左點(diǎn)擊
win32api.mouse_event(win32con.MOUSEEVENTF_LEFTDOWN, 100, 100, 0, 0)
time.sleep(2)
win32api.mouse_event(win32con.MOUSEEVENTF_LEFTUP, 100, 100, 0, 0)

8、關(guān)于鼠標(biāo)鍵盤的操作還可以使用PyUserInput庫

PyUserInput是一個(gè)使用python的跨平臺(tái)的操作鼠標(biāo)和鍵盤的模塊,使用非常方便。支持的平臺(tái)及依賴如下:

  • Linux - Xlib

  • Mac - Quartz, AppKit

  • Windows - pywin32, pyHook

實(shí)例化一個(gè)鼠標(biāo)和鍵盤對(duì)象,如下所示:

from pymouse import PyMouse
from pykeyboard import PyKeyboard
m = PyMouse()
k = PyKeyboard()
操作鼠標(biāo)和鍵盤,如下所示:
m.click(190,70,1)#移動(dòng)并且在xy位置點(diǎn)擊
time.sleep(2)
m.click(190, 200, 1)#移動(dòng)并且在xy位置點(diǎn)擊
time.sleep(2)
k.tap_key(k.function_keys[5])#–點(diǎn)擊功能鍵F5

感謝各位的閱讀!關(guān)于“使用Python自動(dòng)控制windows桌面的案例”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí),如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI