Python中的win32.Dispatch與win32.gencache。優(yōu)缺點(diǎn)都有什么?
您需要閱讀的一件事是此鏈接。
我會(huì)盡力回答您的問(wèn)題,但我不是專家。
COM使用python創(chuàng)建對(duì)象時(shí),python如何知道該對(duì)象可用的方法和參數(shù)?這與 和 綁定的概念有關(guān)。
如果嘗試創(chuàng)建一個(gè)COM以前從未使用過(guò)的對(duì)象dispatch,則不會(huì)知道該對(duì)象有什么可用的對(duì)象。如果我在Jupyter QtConsole中進(jìn)行操作:
import win32com.client as win32xl_dis = win32.dispatch('Excel.Application')xl_disOut[3]: <COMObject Excel.Application>
然后嘗試xl_dis.看看以后我能做什么,我別無(wú)選擇。我在 的情況下,“ python不知道對(duì)象可以做什么”。
如果我做同樣的事情Ensuredispatch:
import win32com.client as win32xl_ens = win32.gencache.Ensuredispatch('Excel.Application')xl_ensOut[3]: <win32com.gen_py.Microsoft Excel 14.0 Object Library._Application instance at 0x35671240>
首先,您可以看到輸出的差異,然后,如果我這樣做,xl_ens.我將獲得一些可用的方法和參數(shù)。我現(xiàn)在處于 ,“python知道對(duì)象可以做什么”。
發(fā)生的結(jié)果是Ensuredispatch強(qiáng)制首先運(yùn)行makepy.py(在您的folder中查看Libsite-packageswin32comclient)以創(chuàng)建一個(gè)Libsite-packageswin32comgen_py包含python腳本的文件夾,其中包含與此COM對(duì)象相關(guān)的一些方法和參數(shù)。
現(xiàn)在,如果您在使用的新控制臺(tái)中再次嘗試dispatch,您將獲得完全相同的結(jié)果。實(shí)際上,在使用之后Ensuredispatch,in中之前創(chuàng)建的文件夾win32comgen_py仍然存在,并且“python仍然知道對(duì)象可以做什么”。要自己進(jìn)行實(shí)驗(yàn),請(qǐng)轉(zhuǎn)到您的文件夾win32comgen_py并刪除包含excel信息的文件夾(對(duì)我來(lái)說(shuō),名稱是00020813-0000-0000-C000-000000000046x0x1x7,不確定與您的名稱是否相同)。
最后,兩者之間的主要區(qū)別是第一次創(chuàng)建COM對(duì)象時(shí)是否強(qiáng)制早期綁定,但是如果與COM對(duì)象相關(guān)的文件夾已經(jīng)存在win32comgen_py,則沒(méi)有太大區(qū)別。
我給的鏈??接的這兩句話:
要強(qiáng)制使用早期綁定來(lái)訪問(wèn)COM對(duì)象,必須在代碼中強(qiáng)制執(zhí)行MakePy進(jìn)程。確保存在MakePy支持后,照常使用win32com.client.dispatch()。它總是為您的COM對(duì)象返回MakePy支持的包裝器。
為了強(qiáng)制執(zhí)行MakePy進(jìn)程,使用了win32com.client.gencache模塊。該模塊包含管理MakePy生成的源文件目錄的代碼:生成的緩存或gencache。此模塊中有許多有用的功能,如果需要對(duì)這些生成的文件進(jìn)行高級(jí)管理,建議您瀏覽源文件。
總結(jié)一下。
另一種選擇是使用dynamic諸如win32.dynamic.dispatch('Excel.Application')和這樣,您將始終COM在后期綁定中獲得對(duì)象。
解決方法我最近一直在使用python的win32com.client作為Windows應(yīng)用程序的API,但正在努力了解一些基本知識(shí)。
我一直通過(guò)以下方式將其用于名為WEAP的程序中
import win32com.clientwin32com.client.Dispatch('WEAP.WEAPApplication')
現(xiàn)在,我想將其與Excel一起使用,并找到了前幾行的替代方法,其中之一如下
import win32com.client as win32excel = win32.gencache.EnsureDispatch(’Excel.Application’)
有誰(shuí)知道使用之間的區(qū)別
win32.Dispatch
和
win32.gencache.EnsureDispatch
和其他選擇?有誰(shuí)知道每個(gè)人的利弊?或有關(guān)何時(shí)應(yīng)使用一個(gè)或另一個(gè)的一些建議?
但是,他們通常專注于回答特定問(wèn)題,而不是描述Dispatch,gencache.EnsureDispatch以及其他替代方案(我想要的)之間更大的區(qū)別。
任何建議將不勝感激。
相關(guān)文章:
1. 淺談SpringMVC jsp前臺(tái)獲取參數(shù)的方式 EL表達(dá)式2. jsp+servlet簡(jiǎn)單實(shí)現(xiàn)上傳文件功能(保存目錄改進(jìn))3. javascript xml xsl取值及數(shù)據(jù)修改第1/2頁(yè)4. XML入門的常見(jiàn)問(wèn)題(四)5. HTML5 Canvas繪制圖形從入門到精通6. XML入門的常見(jiàn)問(wèn)題(一)7. JavaWeb Servlet中url-pattern的使用8. 微信開(kāi)發(fā) 網(wǎng)頁(yè)授權(quán)獲取用戶基本信息9. XML解析錯(cuò)誤:未組織好 的解決辦法10. asp批量添加修改刪除操作示例代碼
