在多线程中使用win32com

文章讲述了如何在Python中使用win32com库时,在不同线程间安全地传递COMObject。通过CoMarshalInterThreadInterfaceInStream和CoGetInterfaceAndReleaseStream函数,可以实现线程间的Excel.Application实例共享。示例代码创建了一个新线程,将Excel实例ID传递给它,然后在线程内部使用CoGetInterfaceAndReleaseStream恢复接口。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

如果要在多个线程中使用win32com,需要使用CoMarshalInterThreadInterfaceInStream()和CoGetInterfaceAndReleaseStream()在线程之间传递实例,因为COMObject不能直接传递给线程:

import pythoncom, win32com.client, threading, time

def start():
    # Initialize
    pythoncom.CoInitialize()

    # Get instance
    xl = win32com.client.Dispatch('Excel.Application')

    # Create id
    xl_id = pythoncom.CoMarshalInterThreadInterfaceInStream(pythoncom.IID_IDispatch, xl)

    # Pass the id to the new thread
    thread = threading.Thread(target=run_in_thread, kwargs={'xl_id': xl_id})
    thread.start()

    # Wait for child to finish
    thread.join()

def run_in_thread(xl_id):
    # Initialize
    pythoncom.CoInitialize()

    # Get instance from the id
    xl = win32com.client.Dispatch(
            pythoncom.CoGetInterfaceAndReleaseStream(xl_id, pythoncom.IID_IDispatch)
    )
    time.sleep(5)


if __name__ == '__main__':
    start()

有关详细信息,请参见:https://mail.python.org/pipermail/python-win32/2008-June/007788.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值