python模塊詳解之pywin32使用文檔(python操作windowsAPI)
一、pywin32簡介
1、windowsAPI是什么
Windows API(Application Programming Interface)是一組函數(shù)、數(shù)據(jù)結(jié)構(gòu)、指令集等的集合,用于操作和控制Windows操作系統(tǒng)的各種功能和特性。它提供了一種通過編程方式與Windows進行交互的接口。
Windows API允許開發(fā)人員使用編程語言(如C/C++、Python等)調(diào)用和使用Windows操作系統(tǒng)的內(nèi)部功能,如創(chuàng)建和管理進程、訪問和修改文件系統(tǒng)、讀取和寫入注冊表、繪制圖形、操作窗口和控件、網(wǎng)絡(luò)通信等。通過Windows API,開發(fā)人員可以利用操作系統(tǒng)提供的功能和資源,構(gòu)建各種類型的應(yīng)用程序。
Windows API以動態(tài)鏈接庫(DLL)的形式提供,開發(fā)人員可以通過引入相應(yīng)的庫文件并使用庫中的函數(shù)和數(shù)據(jù)結(jié)構(gòu),來實現(xiàn)對特定功能的調(diào)用和操作。使用Windows API可以完成從底層系統(tǒng)操作到高級應(yīng)用程序開發(fā)的各個層次的任務(wù)。
Windows API是使用非常廣泛的API之一,廣泛應(yīng)用于Windows軟件開發(fā)、系統(tǒng)編程、驅(qū)動程序開發(fā)等領(lǐng)域。
win32API參考手冊:http://www.yfvb.com/help/win32sdk/index.htm
微軟win32API手冊:https://learn.microsoft.com/zh-cn/windows/win32/
2、pywin32模塊
pywin32是一個Python擴展模塊,它提供了與Windows操作系統(tǒng)的API進行交互的功能。具體而言,pywin32模塊可以用于在Python中調(diào)用和操作Windows的各種系統(tǒng)功能,包括但不限于以下功能:
- 與Windows API的交互:pywin32提供了對Windows的API函數(shù)的封裝,使得在Python中可以直接調(diào)用這些API函數(shù)進行操作,如創(chuàng)建和管理進程、訪問和修改注冊表、操作文件和文件夾等。
- COM組件和ActiveX對象的操作:pywin32支持使用COM技術(shù)(Component Object Model)與Windows操作系統(tǒng)中的COM組件進行交互。通過pywin32,可以創(chuàng)建、操縱和使用COM組件、ActiveX對象和OLE對象,實現(xiàn)與Windows應(yīng)用程序和組件的集成。
- Windows服務(wù)的管理:pywin32提供了管理Windows服務(wù)的功能,可以通過pywin32創(chuàng)建和管理Windows服務(wù),包括安裝、啟動、停止和刪除Windows服務(wù)。
- GUI編程:pywin32模塊還提供了與Windows的圖形用戶界面(GUI)進行交互的功能。它可以創(chuàng)建和操作Windows窗口、對話框,以及訪問和修改窗口控件的屬性和事件。
總之,pywin32模塊提供了豐富的功能和方法,可以在Python中直接調(diào)用Windows操作系統(tǒng)的API,實現(xiàn)與Windows相關(guān)的操作和功能。
該項目是開源的,地址為:https://github.com/mhammond/pywin32
api地址為:http://timgolden.me.uk/pywin32-docs/contents.html
3、安裝pywin32
# 直接安裝 pip install pywin32
安裝完成之后,在python安裝目錄下:\Lib\site-packages,會有一個PyWin32.chm文件,就是使用文檔。
pywin32把Windows API按照功能分了一些大類,每一個大類作為一個模塊。以下是所有的模塊:
_winxptheme:提供專為xp系統(tǒng)的主題API
mmapfile:編譯的擴展模塊,提供對內(nèi)存映射文件API的訪問
odbc:odb數(shù)據(jù)庫api
perfmon:包裝性能監(jiān)視器功能的模塊。
pywintypes:支持常見 Windows 類型的模塊。
servicemanager:與 Windows 服務(wù)控制管理器交互的模塊。
timer:包裝 Win32 Timer 函數(shù)的擴展
win2kras:將 Windows 2000 擴展封裝到遠程訪問服務(wù) (RAS) API 的模塊。
win32api:提供了常用的用戶API
win32clipboard:提供了有關(guān)粘貼板的API
win32con:有關(guān)的常量
win32console:控制臺
win32cred:憑證管理功能的接口。此模塊中的功能僅適用于 Windows XP 及更高版本。
win32crypt:win32 Cryptography API 的接口
win32event:提供了win32事件/等待API
win32evtlog:封裝了 Windows Win32 事件日志 API。
win32file:提供了有關(guān)文件操作的API
win32gui:提供了有關(guān)windows用戶界面圖形操作的API
win32help:Win32 help API’s
win32inet:Windows internet (wininet) API的接口
win32job:win32進程和線程API的接口,可在Windows 2000及更高版本中使用。
win32lz:封裝 Windows LZ 壓縮例程的模塊
win32net:Windows internet (wininet) API的接口
win32pdh:封裝了Windows性能數(shù)據(jù)助手API
win32pipe:管道api
win32print:封裝Windows打印API
win32process:進程api
win32profile:包裝用于處理用戶配置文件的函數(shù)
win32ras:封裝Windows遠程訪問服務(wù)(RAS) API
win32security:win32安全API的接口
win32service:服務(wù)
win32trace
win32transaction:用于事務(wù)化的NTFS和事務(wù)化的注冊表函數(shù)
win32ts:這個模塊中的所有函數(shù)都接受關(guān)鍵字參數(shù)
win32wnet:公開Windows網(wǎng)絡(luò)API
winxpgui:xp圖像用戶界面API
二、常用模塊:pywintypes
0、使用
使用前需要引入:
import pywintypes
1、CreateGuid:生成唯一標識符
返回一個字符串,格式為{xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx}。
PyIID = pywintypes.CreateGuid()
print(PyIID) # {BB02ECB7-BC18-4336-A65C-C9C0CE548020}
三、常用模塊:win32api
0、使用
使用前需要引入:
import win32api
1、AbortSystemShutdown:關(guān)機
import win32api # 取消系統(tǒng)關(guān)閉操作 win32api.AbortSystemShutdown(computer_name=None)
該方法的參數(shù)computer_name是可選的,用于指定要取消系統(tǒng)關(guān)閉操作的計算機名稱。如果未提供computer_name參數(shù),則默認為本地計算機。
注意:該方法要求以管理員權(quán)限運行,否則會拋出權(quán)限錯誤。
2、Beep:發(fā)出聲音
import win32api # 發(fā)出一次短促的蜂鳴聲 win32api.Beep(freq, duration)
該方法接受兩個參數(shù):
freq:表示發(fā)聲的頻率,以赫茲(Hz)為單位。常見的頻率可以嘗試使用440(標準音A)。duration:表示發(fā)聲持續(xù)的時間,以毫秒(ms)為單位。
請注意,該方法可能不適用于所有的計算機和操作系統(tǒng)。在某些系統(tǒng)中可能無法產(chǎn)生蜂鳴聲音。
3、ClipCursor:限制鼠標范圍
在pywin32模塊中,win32api.ClipCursor方法用于限制鼠標光標的移動范圍在指定的矩形區(qū)域內(nèi)。
import win32api # 定義矩形的左上角和右下角坐標 left, top, right, bottom = 100, 100, 500, 500 # 創(chuàng)建矩形對象 rect = (left, top, right, bottom) # 限制鼠標光標的移動范圍 win32api.ClipCursor(rect) # 取消限制,恢復(fù)正常的鼠標光標移動范圍 win32api.ClipCursor(None)
在這個示例中,首先我們定義了一個矩形區(qū)域的左上角和右下角坐標。然后,使用win32api.ClipCursor方法將鼠標光標的移動范圍限制在該矩形區(qū)域內(nèi),傳入矩形的坐標參數(shù)。最后,使用win32api.ClipCursor(None)取消對鼠標光標移動范圍的限制,恢復(fù)正常的移動范圍。
注意:在使用win32api.ClipCursor方法之后,記得一定要及時取消限制,以免造成鼠標無法移動的情況。
4、CloseHandle:關(guān)閉文件句柄
在pywin32模塊中,win32api.CloseHandle方法用于關(guān)閉一個句柄(handle)。
import win32api
# 打開或創(chuàng)建一個文件,并獲取文件的句柄
handle = win32api.CreateFile("path/to/file", win32api.GENERIC_READ, 0, None, win32api.OPEN_EXISTING, 0, None)
# 使用句柄進行一些操作
# 關(guān)閉句柄
win32api.CloseHandle(handle)
在這個示例中,首先我們使用win32api.CreateFile方法打開或創(chuàng)建一個文件,并獲取文件的句柄。然后,使用這個句柄進行一些操作。最后,使用win32api.CloseHandle方法關(guān)閉句柄,確保資源的釋放和內(nèi)存的回收。
請注意,在使用完句柄后,務(wù)必記得及時關(guān)閉句柄,以免資源泄露或其他不可預(yù)見的問題。
5、CopyFile:復(fù)制文件
import win32api # 源文件路徑 src_file = "path/to/source/file" # 目標文件路徑 dst_file = "path/to/destination/file" # 復(fù)制文件 win32api.CopyFile(src_file, dst_file)
CopyFile支持多傳一個int類型參數(shù):指示如果文件存在,操作是否應(yīng)該失敗,默認為0。
6、DeleteFile:刪除文件
win32api.DeleteFile(fileName)
7、ExitWindows:注銷當前用戶
在pywin32模塊中,win32api.ExitWindows方法用于執(zhí)行系統(tǒng)的關(guān)機、重啟、注銷或關(guān)閉等操作。
import win32api # 執(zhí)行關(guān)機操作(將在 30 秒后關(guān)機) win32api.ExitWindowsEx(win32api.EWX_SHUTDOWN | win32api.EWX_FORCE, 30)
在這個示例中,我們使用win32api.ExitWindowsEx方法執(zhí)行關(guān)機操作。win32api.EWX_SHUTDOWN指定了要執(zhí)行的操作為關(guān)機操作,win32api.EWX_FORCE指定了強制執(zhí)行關(guān)機操作。最后的參數(shù) 30 表示延遲關(guān)機的時間,單位為秒(默認為 0)。
除了關(guān)機操作,還可以使用其他參數(shù)來執(zhí)行其他操作,如重啟、注銷、鎖定等。以下是一些常用的系統(tǒng)操作參數(shù):
- win32api.EWX_LOGOFF:注銷
- win32api.EWX_REBOOT:重啟
- win32api.EWX_SHUTDOWN:關(guān)機
- win32api.EWX_POWEROFF:關(guān)閉電源(需要特權(quán))
可以根據(jù)需要選擇適合的操作參數(shù)。請注意,某些操作可能需要管理員權(quán)限才能執(zhí)行成功。
另外,也可以使用win32api.InitiateSystemShutdown方法進行關(guān)機操作,它提供更多的自定義選項。
8、GetComputerName:獲取計算機名
import win32api
# 獲取計算機名稱
computer_name = win32api.GetComputerName()
print(f"Computer Name: {computer_name}")
9、GetCursorPos:返回鼠標位置
import win32api a, b = win32api.GetCursorPos() print(a) print(b)
10、GetLocalTime:獲取當前時間
# 結(jié)果:(2023, 11, 3, 15, 10, 12, 23, 214) win32api.GetLocalTime() win32api.GetSystemTime()
11、MessageBeep:發(fā)出預(yù)定義的聲音
win32api.MessageBeep(1)
12、TerminateProcess:終止進程
import win32api
import win32con
# 根據(jù)進程ID終止進程
def kill_process_by_pid(pid):
# 打開進程句柄
handle = win32api.OpenProcess(win32con.PROCESS_TERMINATE, False, pid)
if handle:
# 終止進程
win32api.TerminateProcess(handle, 0)
# 關(guān)閉進程句柄
win32api.CloseHandle(handle)
# 根據(jù)進程名稱終止進程
def kill_process_by_name(name):
import psutil
for process in psutil.process_iter(['name', 'pid']):
if process.info['name'] == name:
pid = process.info['pid']
kill_process_by_pid(pid)
# 終止名為"program_name.exe"的進程
kill_process_by_name("program_name.exe")
在上面的代碼中,我們定義了兩個函數(shù):kill_process_by_pid()和kill_process_by_name()。kill_process_by_pid()函數(shù)使用進程ID(pid)來終止進程,而kill_process_by_name()函數(shù)使用進程名稱來終止進程。在kill_process_by_name()函數(shù)中,我們使用了psutil模塊來獲取正在運行的進程列表,并根據(jù)進程名稱匹配要終止的進程。
請注意,在使用win32api.TerminateProcess()函數(shù)時,要謹慎操作,因為它可以立即終止進程,而不進行任何清理工作。
13、其他
還有各種內(nèi)存、文件、鼠標、鍵盤等操作的。
四、剪切板模塊:win32clipboard
win32clipboard 模塊提供了對 Windows 系統(tǒng)剪貼板的訪問。
以下是 win32clipboard 模塊的常用方法和屬性:
- OpenClipboard(hwnd):打開剪貼板。hwnd 是一個可選參數(shù),用于指定當前活動窗口的句柄。
- CloseClipboard():關(guān)閉剪貼板。
- EmptyClipboard():清空剪貼板。
- GetClipboardData(format):獲取剪貼板中的數(shù)據(jù)。format 是一個可選參數(shù),用于指定數(shù)據(jù)的格式。常見的格式有:
- win32con.CF_TEXT:文本格式
- win32con.CF_UNICODETEXT:Unicode 文本格式
- win32con.CF_DIB:位圖格式
- SetClipboardData(format, data):設(shè)置剪貼板中的數(shù)據(jù)。format 是數(shù)據(jù)的格式,data 是要設(shè)置的數(shù)據(jù)。
- IsClipboardFormatAvailable(format):檢查指定格式的數(shù)據(jù)是否在剪貼板中可用。
import win32clipboard import win32con # 打開剪貼板 win32clipboard.OpenClipboard() # 清空剪貼板 win32clipboard.EmptyClipboard() # 設(shè)置文本數(shù)據(jù) win32clipboard.SetClipboardData(win32con.CF_TEXT, b"Hello, World!") # 獲取文本數(shù)據(jù) data = win32clipboard.GetClipboardData(win32con.CF_TEXT) print(data) # 檢查指定格式的數(shù)據(jù)是否可用 is_available = win32clipboard.IsClipboardFormatAvailable(win32con.CF_UNICODETEXT) print(is_available) # 關(guān)閉剪貼板 win32clipboard.CloseClipboard()
上述代碼打開剪貼板,清空剪貼板,設(shè)置文本數(shù)據(jù),獲取文本數(shù)據(jù),并檢查指定格式的數(shù)據(jù)是否可用,最后關(guān)閉剪貼板。
五、文件模塊:win32file
win32file模塊是pywin32模塊中的一個子模塊,用于處理Windows文件和文件系統(tǒng)的相關(guān)操作。
win32file模塊提供了一些方法和常量來處理文件的讀寫、文件屬性的獲取和設(shè)置、文件系統(tǒng)的操作等。以下是這個模塊的一些常用方法和功能的詳細說明:
CreateFile(filename, access, share_mode, security_attributes, creation_disposition, flags_and_attributes, template_file):創(chuàng)建或打開一個文件,并返回一個文件句柄。
- CloseHandle(handle):關(guān)閉一個文件句柄。
- ReadFile(handle, buffer, overlapped):從文件中讀取數(shù)據(jù),并將結(jié)果存入指定的緩沖區(qū)。
- WriteFile(handle, buffer, overlapped):將數(shù)據(jù)寫入文件。
- GetFileSize(handle):獲取指定文件的大小。
- SetFileAttributes(filename, file_attributes):設(shè)置文件的屬性,比如只讀、隱藏等。
- GetFileAttributes(filename):獲取文件的屬性。
- DeleteFile(filename):刪除指定的文件。
- GetFileInformationByHandle(handle):通過文件句柄獲取文件的信息,如文件大小、創(chuàng)建時間等。
- FindFirstFile(filename):查找指定文件/文件夾,并返回一個用于遍歷結(jié)果的搜索句柄。
- FindNextFile(handle):通過搜索句柄獲取下一個文件/文件夾的信息。
- FindClose(handle):關(guān)閉搜索句柄。
這些方法提供了對文件和文件系統(tǒng)進行操作的功能。可以使用這些方法來創(chuàng)建、打開、讀寫文件,獲取和設(shè)置文件屬性,刪除文件,遍歷文件夾等等。在使用這些方法之前,需要先安裝pywin32模塊,并導(dǎo)入win32file模塊。
下面是一個示例代碼,演示了如何使用win32file模塊讀取文件的內(nèi)容和獲取文件的大?。?/p>
# 我們使用CreateFile方法打開指定的文件,然后使用GetFileSize方法獲取文件的大小。接著,我們調(diào)用ReadFile方法讀取文件的內(nèi)容,并將結(jié)果返回。最后,我們使用CloseHandle方法關(guān)閉文件句柄。
#注意,在使用win32file模塊時,需要有管理員權(quán)限或具有適當?shù)臋?quán)限來訪問和操作文件。
import win32file
def read_file(filename):
try:
# 打開文件
handle = win32file.CreateFile(filename, win32file.GENERIC_READ, 0, None, win32file.OPEN_EXISTING, 0, 0)
# 獲取文件大小
file_size = win32file.GetFileSize(handle)
# 讀取文件內(nèi)容
buffer = win32file.ReadFile(handle, file_size)
# 關(guān)閉文件句柄
win32file.CloseHandle(handle)
return buffer
except Exception as e:
print("Error:", e)
# 讀取文件內(nèi)容
filename = "test.txt"
file_content = read_file(filename)
print(file_content)
六、ui模塊:win32gui
1、常用方法
win32gui模塊定義了windows窗口的常用方法:
import win32gui # 獲取窗口句柄 hwnd = win32gui.FindWindow(None, "窗口標題") print(hwnd)
# 獲取窗口位置和大?。?
import win32gui
hwnd = win32gui.FindWindow(None, "窗口標題")
rect = win32gui.GetWindowRect(hwnd)
left, top, right, bottom = rect
print("窗口位置:(左:{}, 上:{})".format(left, top))
print("窗口大?。?寬:{}, 高:{})".format(right - left, bottom - top))
# 獲取窗口的父窗口和子窗口:
import win32gui
hwnd = win32gui.FindWindow(None, "窗口標題")
parent_hwnd = win32gui.GetParent(hwnd)
child_hwnds = []
win32gui.EnumChildWindows(hwnd, lambda hwnd, param: param.append(hwnd), child_hwnds)
print("父窗口句柄:", parent_hwnd)
print("子窗口句柄:", child_hwnds)
# 設(shè)置窗口標題: import win32gui hwnd = win32gui.FindWindow(None, "窗口標題") win32gui.SetWindowText(hwnd, "新的窗口標題")
2、獲取窗口并設(shè)為活躍窗口
import win32gui
window_name = "窗口標題"
# 通過窗口名稱獲取窗口句柄
hwnd = win32gui.FindWindow(None, window_name)
if hwnd != 0:
# 將窗口設(shè)為活躍窗口
win32gui.SetForegroundWindow(hwnd)
print("窗口已設(shè)為活躍")
else:
print("未找到該窗口")
該代碼只會將窗口設(shè)為活躍,并不會將其移動到前臺。如果窗口已最小化或位于其他桌面,它可能不會立即顯示在屏幕上。
總結(jié)
到此這篇關(guān)于python模塊詳解之pywin32使用文檔的文章就介紹到這了,更多相關(guān)python模塊pywin32使用內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python pandas進行數(shù)據(jù)預(yù)處理的實現(xiàn)
本案例通過使用pandas庫對電子商務(wù)客戶數(shù)據(jù)進行數(shù)據(jù)預(yù)處理,包括數(shù)據(jù)導(dǎo)入、查看、缺失值處理等處理,具有一定的參考價值,感興趣的可以了解一下2025-01-01

