C#/ IronPython与共享C#类库互操作

前端之家收集整理的这篇文章主要介绍了C#/ IronPython与共享C#类库互操作前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在尝试使用Iron Python作为C#GUI和一些C#库之间的中介,以便它可以在编译后编写脚本.

我有一个类库DLL,由GUI和python使用,是这样的:

  1. namespace MyLib
  2. {
  3. public class MyClass
  4. {
  5. public string Name { get; set; }
  6. public MyClass(string name)
  7. {
  8. this.Name = name;
  9. }
  10. }
  11. }

IronPython代码如下:

  1. import clr
  2. clr.AddReferenceToFile(r"MyLib.dll")
  3. from MyLib import MyClass
  4.  
  5. ReturnObject = MyClass("Test")

然后,在C#中,我将其称为如下:

  1. ScriptEngine engine = Python.CreateEngine();
  2. ScriptScope scope = null;
  3.  
  4. scope = engine.CreateScope();
  5. ScriptSource source = engine.CreateScriptSourceFromFile("Script.py");
  6.  
  7. source.Execute(scope);
  8.  
  9. MyClass mc = scope.GetVariable<MyClass>("ReturnObject ")

当我调用最后一段代码时,source.Execute(scope)运行成功返回,但是当我尝试GetVariable调用时,它抛出以下异常

  1. Microsoft.Scripting.ArgumentTypeException: expected MyClass,got MyClass

所以,你可以看到类名完全相同,但由于某种原因,它认为它们是不同的.

DLL与.py文件位于不同的目录中(我只是没有写出所有路径设置的东西),可能是因为IronPython的解释器存在问题,因为它看起来不同,因为它是某种方式看到他们处于不同的背景或范围?

解决方法

错误表示您的程序集已加载到多个CLR加载程序上下文中.您可以切换到clr.AddReference,也可以从C#加载程序集,而不是使用clr.AddReferenceToFile添加引用.对于前者,您需要确保程序集在.NET可以正常加载的位置(GAC或进程的应用程序库)中可用.对于后者你可以这样做:
  1. engine.Runtime.LoadAssembly(typeof(MyClass).Assembly);

来自您的C#主机代码.就个人而言,我更喜欢这个第二个解决方案,因为它不仅可以帮助您节省用户从Python进行clr.AddRef调用.

猜你在找的C#相关文章