tags:

views:

159

answers:

1

I am trying to do a sample app in python which uses some COM objects. I've read the famous chapter 12 from Python Programing on Win32 but regarding this issue it only states:

All event handling is done using normal IConnectionPoint interfaces, and although beyond the scope of this book, is fully supported by the standard Python COM framework.

Can anybody shed some light on this? I'd need a simple starter sample. Something like adding code to this sample to catch the OnActivate event for the spreadsheet

import win32com.client
xl = win32com.client.Dispatch("Excel.Application")
...
+1  A: 

I haven't automated Excel, but I'm using some code from Microsoft's Speech API that may be similar enough to get you started:

ListenerBase = win32com.client.getevents("SAPI.SpInProcRecoContext")
class Listener(ListenerBase):
    def OnRecognition(self, _1, _2, _3, Result):
        """Callback whenever something is recognized."""
        # Work with Result

    def OnHypothesis(self, _1, _2, Result):
        """Callback whenever we have a potential match."""
        # Work with Result

then later in a main loop:

    while not self.shutting_down.is_set():
        # Trigger the event handlers if we have anything.
        pythoncom.PumpWaitingMessages() 
        time.sleep(0.1) # Don't use up all our CPU checking constantly

Edit for more detail on the main loop:

When something happens, the callback doesn't get called immediately; instead you have to call PumpWaitingMessages(), which checks if there are any events waiting and then calls the appropriate callback.

If you want to do something else while this is happening, you'll have to run the loop in a separate thread (see the threading module); otherwise it can just sit at the bottom of your script. In my example I was running it in a separate thread because I also had a GUI running; the shutting_down variable is a threading.Event you can use to tell the looping thread to stop.

Kiv
Thanks for this. Can you detail a bit the 2nd part ( the loop ) - sorry to bother I am starting fresh on pyhton :).
da_m_n
No problem, see my edit :)
Kiv
:) I know what the message loop is - i cannot seem to find pythoncom - is that a package i need to import?Also I see there's also a DispatchWithEvents method - i will look into that when i get time for this issue.
da_m_n
Yes, pythoncom is a package you need to import; it should come with your Python Win32 Extensions installation (the one that installs Pythonwin, etc).
Kiv