在Windows平臺上,從原來使用C/C++編寫原生EXE程序,到使用Python編寫一些常用腳本程序,成熟的模塊的使用使得編程效率大大提高了。
不過,python模塊雖多,也不可能滿足開發(fā)者的所有需求。而且,模塊為了便于使用,通常都封裝過度,有些功能無法靈活使用,必須直接調(diào)用Windows API來實(shí)現(xiàn)。
要完成這一目標(biāo),有兩種辦法,一種是使用C編寫Python擴(kuò)展模塊,或者就是編寫普通的DLL通過python的ctypes來調(diào)用,但是這樣就部分犧牲掉了Python的快速開發(fā)、免編譯特性。
還好,有一個(gè)模塊pywin32可以解決這個(gè)問題,它直接包裝了幾乎所有的Windows API,可以方便地從Python直接調(diào)用,該模塊另一大主要功能是通過Python進(jìn)行COM編程。
該項(xiàng)目是開源的,項(xiàng)目地址是:https://github.com/mhammond/pywin32
安裝時(shí)可以直接使用pip執(zhí)行“pip install pywin32”來安裝它。
安裝完畢后,在Python安裝路徑下的Lib\site-packages\win32可以看到所有的API支撐模塊,Lib\site-packages\win32com下則是COM的支撐模塊。
在Lib\site-packages下有一個(gè)PyWin32.CHM幫助文件,相信對Windows編程有一定基礎(chǔ)的,看了這個(gè)幫助文件就能很快上手。
簡單說,pywin32把Windows API按照功能分了一些大類,每一個(gè)大類作為一個(gè)模塊。以下是所有的模塊:
mmapfile odbc perfmon servicemanager timer win2kras win32api win32clipboard win32console
win32cred win32crypt win32event win32evtlog win32file win32gui win32help win32inet win32job
win32lz win32net win32pdh win32pipe win32print win32process win32profile win32ras win32security
win32service win32trace win32transaction win32ts win32wnet winxpgui
比如文件類API就在模塊win32file中,進(jìn)程類API在模塊win32process中。
在使用的時(shí)候,按需導(dǎo)入相關(guān)模塊就行了,win32con則定義了所有的常量,幾乎是必不可少的,一些難以分類的API則在模塊win32api中(大部分是kernel32.dll導(dǎo)出的API)。
部分模塊之間還存在一些交叉,比如CreateFile的參數(shù)中用到的GENERIC_READ常量,在win32con中有定義,在win32file中也有定義。
用戶只要大概知道這個(gè)是文件API用到的常量,那么不管你寫win32file.GENERIC_READ還是win32con.GENERIC_READ都是可以的。
關(guān)閉句柄用的CloseHandle函數(shù)也是在兩個(gè)模塊中都有定義的。
需要注意的是,微軟提供的Wsa系列網(wǎng)絡(luò)API也都在win32file模塊中,因?yàn)楹芏嗖僮飨到y(tǒng)都是把套接字也用為文件對象來操作的。
如果你不清楚要使用的API在哪個(gè)模塊中,那就到幫助文件里搜索一下,一定會給你答案的。
如果你只是對pywin32中如何調(diào)用某個(gè)API不熟悉,那么查看Pywin32.CHM就足夠了,如果你對API本身的參數(shù)定義和使用不熟悉,那還得繼續(xù)看MSDN。
下面來寫一個(gè)Helloworld作為開始吧:
1 2 3 | import win32api import win32con win32api.MessageBox( None , "Hello,pywin32!" , "pywin32" ,win32con.MB_OK) |
效果如下:
在Lib\site-packages\win32\Demos目錄下有許多例子,如果你還不清楚pywin32怎么上手,來看看這些例子就知道了。
比如使用API進(jìn)行文件操作:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 | # This is a "demo" of win32file - it used to be more a test case than a # demo, so has been moved to the test directory. # Please contribute your favourite simple little demo. import win32file, win32api, win32con import os # A very simple demo - note that this does no more than you can do with # builtin Python file objects, so for something as simple as this, you # generally *should* use builtin Python objects. Only use win32file etc # when you need win32 specific features not available in Python. def SimpleFileDemo(): testName = os.path.join( win32api.GetTempPath(), "win32file_demo_test_file" ) if os.path.exists(testName): os.unlink(testName) # Open the file for writing. handle = win32file.CreateFile(testName, win32file.GENERIC_WRITE, 0 , None , win32con.CREATE_NEW, 0 , None ) test_data = "Hello\0there" .encode( "ascii" ) win32file.WriteFile(handle, test_data) handle.Close() # Open it for reading. handle = win32file.CreateFile(testName, win32file.GENERIC_READ, 0 , None , win32con.OPEN_EXISTING, 0 , None ) rc, data = win32file.ReadFile(handle, 1024 ) handle.Close() #此處也可使用win32file.CloseHandle(handle)來關(guān)閉句柄 if data = = test_data: print "Successfully wrote and read a file" else : raise Exception( "Got different data back???" ) os.unlink(testName) if __name__ = = '__main__' : SimpleFileDemo() |
可以看一看上面的例子是如何使用Windows API的,相信對于pywin32模塊的使用會有一個(gè)初步的認(rèn)識。
有了pywin32模塊的輔助,對于Windows下的Python編程絕對是如虎添翼。