枫叶棋语 发表于 2023-9-2 16:27:24

浅谈 Ironpython 与Cpython两种引擎对于com 的区别

本帖最后由 枫叶棋语 于 2023-9-2 16:30 编辑


1.浅谈Ironpython 与Cpython的Com区别 Ironpython的com 是利用System库进行操作进程
import System
from System.Runtime.InteropServices import Marshal
from System import Type, Activator
def IpyCom(progid):
    try:
      return Marshal.GetActiveObject(progid)
    except:
      try:
            t = Type.GetTypeFromProgID(progid)
            return Activator.CreateInstance(t)
      except:
            pass
#Com excel,可以在线操作Excel,不用重新打开
exapp = IpyCom("Excel.Application")
worksheet = exapp.ActiveSheet
acell = exapp.ActiveCell


Cpython 的com使用pywin32 库进行操作
import win32com.client as cpycom
exapp = cpycom.Dispatch('Excel.Application')
worksheet = exapp.ActiveSheet
acell = exapp.ActiveCell


只是exapp 的获取方式不同,后续的代码操作基本一致,由于Ironpython 是基于.net平台开发,对System的数据类型是支持的,而win32com是python 平台,对System 的数组会转换为变体,两者稍微有差异,但性能一致。

闻人南131 发表于 2023-9-4 10:47:12

紫苏炒黄瓜 发表于 2023-9-4 10:59:16

途经宝地,支持一下

枫叶棋语 发表于 2023-9-6 12:53:40

紫苏炒黄瓜 发表于 2023-9-4 10:59
途经宝地,支持一下

感谢支持,可以加入群聊一起沟通

qiyang 发表于 2023-9-28 14:26:24

顶你一下:lol:lol
页: [1]
查看完整版本: 浅谈 Ironpython 与Cpython两种引擎对于com 的区别