Python中pywin32 常用窗口操作的實(shí)現(xiàn)
pywin32 主要的作用是供 Python開發(fā)者快速調(diào)用 Windows API的一個(gè)模塊庫(kù)。
獲取窗口句柄
獲取最前端窗口句柄
import win32gui
if __name__ == '__main__':
hwnd = win32gui.GetForegroundWindow() # 獲取最前窗口句柄
print(hwnd) # 197590。返回的句柄是一個(gè) int 類型的值,用于標(biāo)識(shí)對(duì)應(yīng)的窗口
獲取指定坐標(biāo)處的窗口
import win32gui
if __name__ == '__main__':
point = (100, 100)
hwnd = win32gui.WindowFromPoint(point) # 獲取指定坐標(biāo)處的窗口句柄
print(hwnd) # 197590
根據(jù)窗口的完整標(biāo)題匹配獲取句柄
import win32gui
if __name__ == '__main__':
hwnd = win32gui.FindWindow(0, 'tmp_project – test2.py Administrator') # 根據(jù)窗口的完整標(biāo)題匹配獲取句柄
print(hwnd) # 197590
根據(jù)窗口的類別匹配獲取句柄
import win32gui
if __name__ == '__main__':
hwnd = win32gui.FindWindow('SunAwtFrame', None) # 根據(jù)窗口的類別匹配獲取句柄
print(hwnd) # 197590
通過(guò)窗口枚舉獲取句柄
import win32gui
def get_win_title(hwnd, _):
if not win32gui.IsWindowVisible(hwnd):
return
win_text = win32gui.GetWindowText(hwnd) # 獲取窗口的標(biāo)題
win_text = win_text.strip()
if not win_text:
return
print(f"id:{hwnd}, title: {win_text}")
if __name__ == '__main__':
win32gui.EnumWindows(get_win_title, None)
# id:197590, title: tmp_project – test2.py Administrator
# id:132096, title: win32處理_win32gui.enumwindows-CSDN博客 - Google Chrome
# id:66370, title: 飛書
# id:262198, title: 設(shè)置
# id:131272, title: Microsoft Text Input Application
# id:65854, title: Program Manager
通過(guò)父窗口句柄查詢子窗口句柄
比如在文件上傳窗口進(jìn)行文件上傳和確認(rèn)操作
import os.path
import time
import win32con
import win32gui
# 自動(dòng)選擇文件并確認(rèn)
def file_upload(file):
retry_times = 3
while retry_times > 0:
time.sleep(3)
dialog = win32gui.FindWindow('#32770', '打開')
if dialog:
break
retry_times -= 1
time.sleep(3)
ComboBoxEx32 = win32gui.FindWindowEx(dialog, 0, 'ComboBoxEx32', None)
ComboBox = win32gui.FindWindowEx(ComboBoxEx32, 0, 'ComboBox', None)
Edit = win32gui.FindWindowEx(ComboBox, 0, 'Edit', None)
Button = win32gui.FindWindowEx(dialog, 0, 'Button', None)
win32gui.SendMessage(Edit, win32con.WM_SETTEXT, None, file)
time.sleep(1)
win32gui.SendMessage(dialog, win32con.WM_COMMAND, 1, Button)
time.sleep(1)
return True
if __name__ == '__main__':
file = os.path.join(os.getcwd(), "test.txt")
print(file)
file_upload(file)
獲取窗口信息
標(biāo)題類名尺寸位置
import win32gui
if __name__ == '__main__':
hwnd = win32gui.GetForegroundWindow() # 獲取窗口句柄
title = win32gui.GetWindowText(hwnd) # 獲取窗口標(biāo)題
print(title) # tmp_project – test2.py Administrator
class_name = win32gui.GetClassName(hwnd) # 獲取窗口類名
print(class_name) # SunAwtFrame
window_rect = win32gui.GetWindowRect(hwnd) # 獲取窗口位置和尺寸
print(window_rect) # (-8, -8, 1928, 1048)
is_iconic = win32gui.IsIconic(hwnd)
print(is_iconic) # 檢查窗口是否最小化 1:是,0:不是
設(shè)置窗口信息
設(shè)置窗口位置和尺寸
import win32gui
if __name__ == '__main__':
hwnd = win32gui.GetForegroundWindow() # 獲取窗口句柄
window_rect = win32gui.GetWindowRect(hwnd) # 獲取窗口位置和尺寸
print(window_rect) # (-8, -8, 1928, 1048)
# 參數(shù):句柄,窗口左邊界,窗口上邊界,窗口寬度,窗口高度,確定窗口是否被刷新
win32gui.MoveWindow(hwnd, 0, 0, 600, 400, True)
設(shè)置窗口狀態(tài)
ShowWindow 常用可選值。
| 預(yù)定義值 | 說(shuō)明 |
|---|---|
| SW_HIDE | 隱藏窗口 |
| SW_SHOW | 顯示窗口 |
| SW_MAXIMIZE | 最大化窗口 |
| SW_MINIMIZE | 最小化窗口 |
| SW_RESTORE | 從最大化最小化恢復(fù)至正常大小 |
| SW_SHOWNORMAL | 顯示并激活窗口,恢復(fù)至正常大小 |
| SW_SHOWMAXIMIZE | 以最大化顯示窗口 |
| SW_SHOWMINIMIZE | 以最小化顯示窗口 |
| SW_SHOWNOACTIVATE | 顯示窗口,激活狀態(tài)不變 |
| ... | ... |
import win32gui
import win32con
if __name__ == '__main__':
hwnd = 197590
win32gui.ShowWindow(hwnd, win32con.SW_SHOWNORMAL) # 正常展示
win32gui.ShowWindow(hwnd, win32con.SW_HIDE) # 隱藏窗口,最好不要單獨(dú)測(cè)這一條,不然你的窗口就不見了
win32gui.ShowWindow(hwnd, win32con.SW_SHOW) # 顯示窗口
win32gui.ShowWindow(hwnd, win32con.SW_RESTORE) # 恢復(fù)窗口并且激活該窗口
win32gui.SetForegroundWindow(hwnd) # 設(shè)置為最前窗口并且激活該窗口
win32gui.ShowWindow(hwnd, win32con.SW_MAXIMIZE) # 窗口最大化
# 通過(guò)句柄窗口置頂(一直置前)
win32gui.SetWindowPos(hwnd, win32con.HWND_TOPMOST, 0, 0, 0, 0,
win32con.SWP_NOMOVE | win32con.SWP_NOACTIVATE | win32con.SWP_NOOWNERZORDER | win32con.SWP_SHOWWINDOW | win32con.SWP_NOSIZE)
# 通過(guò)句柄取消窗口置頂
win32gui.SetWindowPos(hwnd, win32con.HWND_NOTOPMOST, 0, 0, 0, 0,
win32con.SWP_SHOWWINDOW | win32con.SWP_NOSIZE | win32con.SWP_NOMOVE)
關(guān)閉窗口
import win32gui
import win32con
if __name__ == '__main__':
hwnd = 197590
win32gui.SendMessage(hwnd, win32con.WM_CLOSE)
模擬鼠標(biāo)操作
獲取鼠標(biāo)坐標(biāo)位置
import win32api
if __name__ == '__main__':
# 設(shè)置位置
win32api.SetCursorPos((100, 100))
# 獲取位置
point = win32api.GetCursorPos()
print(point) # (100, 100)
鼠標(biāo)點(diǎn)擊事件 通過(guò) win32api.mouse_event(flags, x, y, data, extra_info) 進(jìn)行鼠標(biāo)操作:
MOUSEEVENTF_LEFTDOWN: 按下鼠標(biāo)左鍵 MOUSEEVENTF_LEFTUP: 松開鼠標(biāo)左鍵 MOUSEEVENTF_RIGHTDOWN: 按下鼠標(biāo)右鍵 MOUSEEVENTF_RIGHTUP: 松開鼠標(biāo)右鍵 MOUSEEVENTF_MIDDLEDOWN: 按下鼠標(biāo)中鍵 MOUSEEVENTF_MIDDLEUP: 松開鼠標(biāo)中鍵 MOUSEEVENTF_WHEEL: 鼠標(biāo)輪移動(dòng),數(shù)量由data給出
鼠標(biāo)點(diǎn)擊和滾動(dòng)
import win32api
import win32con
if __name__ == '__main__':
# 模擬鼠標(biāo)在(400, 500)位置進(jìn)行點(diǎn)擊操作
win32api.SetCursorPos((400, 500))
win32api.mouse_event(win32con.MOUSEEVENTF_LEFTDOWN, 0, 0)
win32api.mouse_event(win32con.MOUSEEVENTF_LEFTUP, 0, 0)
win32api.mouse_event(win32con.MOUSEEVENTF_WHEEL, 0, 0, -500, 0) # 滾輪移動(dòng)。正值表示向上滾動(dòng),負(fù)值表示向下滾動(dòng)
模擬鍵盤操作
模擬鍵盤輸入
通過(guò) keybd_event(bVk, bScan, dwFlags, dwExtraInfo) 進(jìn)行監(jiān)聽鍵盤事件:
bVk: 虛擬鍵碼
bScan: 硬件掃描碼,一般設(shè)置為0即可
dwFlags: 函數(shù)操作的一個(gè)標(biāo)志位
值為KEYEVENTF_EXTENDEDKEY則該鍵被按,值為KEYEVENTF_KEYUP則該按鍵被釋放
dwExtraInfo:定義與擊鍵相關(guān)的附加的32位值,一般設(shè)置為0即可比如模擬輸入字符串:
import win32api
import win32con
def type_character(character):
vk_code = win32api.VkKeyScan(character)
if character in 'ABCDEFGHIJKLMNOPQRSTUVWXYZ~!@#$%^&*()_+{}|:"<>?':
win32api.keybd_event(16, 0, 0, 0) # 相當(dāng)于按下 Shift 鍵
win32api.keybd_event(vk_code, 0, 0, 0)
win32api.keybd_event(vk_code, 0, win32con.KEYEVENTF_KEYUP, 0)
win32api.keybd_event(16, 0, win32con.KEYEVENTF_KEYUP, 0)
else:
win32api.keybd_event(vk_code, 0, 0, 0)
win32api.keybd_event(vk_code, 0, win32con.KEYEVENTF_KEYUP, 0)
def type_string(text):
for char in text:
type_character(char)
if __name__ == '__main__':
type_string("Hello")
虛擬鍵碼表
當(dāng)然,鍵盤輸入要對(duì)應(yīng)著虛擬鍵碼表來(lái)按下指定鍵位,比如 Shift 鍵對(duì)應(yīng)的碼值是 16:



獲取本機(jī)IP
import socket
if __name__ == '__main__':
print(socket.gethostbyname(socket.gethostname())) # 10.111.120.196列數(shù)轉(zhuǎn)換成 Excel 列名
def number_to_excel_column(n):
"""列數(shù)轉(zhuǎn)換成 excel 列"""
result = ''
while n > 0:
n, r = divmod(n - 1, 26)
result = chr(65 + r) + result
return result
if __name__ == '__main__':
print(number_to_excel_column(53)) # BA到此這篇關(guān)于Python中pywin32 常用窗口操作的實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)pywin32 常用窗口操作內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
簡(jiǎn)單了解django索引的相關(guān)知識(shí)
這篇文章主要介紹了簡(jiǎn)單了解django索引的相關(guān)知識(shí),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-07-07
python中創(chuàng)建以及刪除虛擬環(huán)境的幾種方法總結(jié)
在Python?中創(chuàng)建虛擬環(huán)境非常容易,但是刪除虛擬環(huán)境可能會(huì)有一些挑戰(zhàn),這篇文章主要給大家介紹了關(guān)于python中創(chuàng)建以及刪除虛擬環(huán)境的幾種方法,需要的朋友可以參考下2024-03-03
python使用多線程查詢數(shù)據(jù)庫(kù)的實(shí)現(xiàn)示例
這篇文章主要介紹了python使用多線程查詢數(shù)據(jù)庫(kù)的實(shí)現(xiàn)示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-08-08
pandas數(shù)據(jù)清洗實(shí)現(xiàn)刪除的項(xiàng)目實(shí)踐
本文主要介紹了pandas數(shù)據(jù)清洗實(shí)現(xiàn)刪除的項(xiàng)目實(shí)踐,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-06-06
python學(xué)習(xí)教程之socket庫(kù)的基本使用(網(wǎng)絡(luò)編程-套接字)
Python中的socket模塊提供了網(wǎng)絡(luò)編程中的套接字(socket)功能,通過(guò)套接字我們可以實(shí)現(xiàn)不同計(jì)算機(jī)之間的通信,這篇文章主要給大家介紹了關(guān)于python學(xué)習(xí)教程之socket庫(kù)的基本使用,需要的朋友可以參考下2024-07-07
如何使用Python實(shí)現(xiàn)CartPole游戲
在深度強(qiáng)化學(xué)習(xí)內(nèi)容的介紹中,提出了CartPole游戲進(jìn)行深度強(qiáng)化學(xué)習(xí),現(xiàn)在提供一種用Python簡(jiǎn)單實(shí)現(xiàn)Cart Pole游戲的方法,感興趣的朋友跟隨小編一起看看吧2024-07-07
Python實(shí)現(xiàn)的井字棋(Tic Tac Toe)游戲示例
這篇文章主要介紹了Python實(shí)現(xiàn)的井字棋(Tic Tac Toe)游戲,結(jié)合實(shí)例形式分析了井字棋的原理及Python相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2018-01-01
使用Python實(shí)現(xiàn)Excel表格轉(zhuǎn)圖片
在數(shù)據(jù)處理與信息分享過(guò)程中,Excel表格作為一種強(qiáng)大的數(shù)據(jù)管理工具被廣泛應(yīng)用,這篇文章主要為大家詳細(xì)介紹了如何使用Python將Excel表格轉(zhuǎn)換為圖片,需要的可以參考下2024-04-04
pytorch使用resnet快速加載官方提供的預(yù)訓(xùn)練模型
這篇文章主要介紹了pytorch使用resnet快速加載官方提供的預(yù)訓(xùn)練模型方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-09-09

