python无法import clr_带有C#dll AddReference的Python CLR模块可以工作,import不能

这个问题与我无法分享的合理数据有关,但问题很简单。我正在研究PyCharm 2017.1.2、python 2.7.13。在

我有一个特定格式的文件(类似于加密的XML,无法解析),需要将其转换为Excel来修改一些值,然后将其导出回原始格式。出于某些安全原因,我不能绕过这个转换。很好,我有一个Excel外接程序,我可以使用它,在两个C#dll中,它“导入”到Excel格式,然后“导出”回奇怪的XML。在

我也不能使用IronPython,因为我正在设计的软件使用的库是IronPython无法管理的,所以我只能使用旧的python2.7。在

我目前正在使用pythonnet的clr模块将dll导入到我的软件中。导入代码(不合理)如下所示:import clr

import sys

sys.path.append('C:/My/Path/To/The/DLLs/Folder')

clr.AddReference('Microsoft.Office.Interop.Excel, Version=11.0.0.0, Culture=neutral, PublicKeyToken=71e9bce111e9429c')

clr.AddReference('My.ClassLib.DLL')

clr.AddReference('My.ExcelImportExport.DLL')

import Microsoft.Office.Interop.Excel as Excel

try:

from My.ClassLib.DLL import XMLParser

import My.ExcelImportExport.DLL

from My.ExcelImportExport.DLL import DeviceSettingsUtility

except Exception, e:

print unicode(e)

我使用的两个DLL都位于同一个文件夹中。CLR添加dll引用没有问题。在

奇怪的是:使用'My.ClassLib.DLL'一切正常:我可以毫无问题地访问它的类和方法。

但只要我尝试import My.ExcelImportExport.DLL或后面的一行,我就得到了ImportError: No module named My.ExcelImportExport.DLL。这两个问题都来自于cd4{cd4>My.ExcelImportExport.DLL。在

我用反编译器查看了这两个DLL,但没有发现任何使类库.DLL并解释为什么另一个不能

最后,我的问题是:在DLL(C代码)中需要有什么才能导入它?在

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值