Python .NET:“无法实例化枚举” - c#

因此,我设法在Python .NET中导入了托管的.NET程序集,并且可以设置多个对象并调用一些函数,但是我无法弄清楚该对象应该如何工作。

这是我要移植的C#代码:

            // read event sticky clears all initial events
            CML_EVENT_STATUS status=0;
            xAxisAmp.ReadEventSticky(ref status);
            statusTextBox.Text = Convert.ToString(status);

我可以导入CML_EVENT_STATUS,报告它是<class 'CMLCOMLib.CML_EVENT_STATUS'>,但是当我尝试创建它的实例时,出现此错误:

>>> stat = CML_EVENT_STATUS()
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
TypeError: cannot instantiate enumeration

如果还有另一种方法可以调用该函数,则无法解决。我试过调用xAxisAmp.ReadEventSticky()xAxisAmp.ReadEventSticky(0),它们只是返回TypeError: No method matches given arguments

我最接近的是来自xAxisAmp.ReadEventSticky(CML_EVENT_STATUS)的错误:

System.ArgumentException: Object of type 'System.RuntimeType' cannot be converted to type 'CMLCOMLib.CML_EVENT_STATUS&'.

我究竟做错了什么?我找不到有关声明枚举类型或通过引用传递它们的任何文档,这使我发疯。

参考方案

在Python .NET中实例化一个枚举的正确方法是:

stat = CML_EVENT_STATUS.EVENT_STATUS_BRAKE

然后,您可以像这样调用方法:

stat = amp.ReadEventSticky(stat)

请注意,refout参数在Python中的工作方式与在C#中不同。如Writing iron python method with ref or out parameter中更详细的描述,从方法中返回refout参数,而不是修改传入的变量。如果有多个返回值(例如,该方法返回一个值,并且存在一个ref参数),然后将首先返回元组及其方法的返回值,然后依次返回refout参数。

假设ReadEventStickyvoid,这非常简单:它只是返回新的CML_EVENT_STATUS值。

Python GPU资源利用 - python

我有一个Python脚本在某些深度学习模型上运行推理。有什么办法可以找出GPU资源的利用率水平?例如,使用着色器,float16乘法器等。我似乎在网上找不到太多有关这些GPU资源的文档。谢谢! 参考方案 您可以尝试在像Renderdoc这样的GPU分析器中运行pyxthon应用程序。它将分析您的跑步情况。您将能够获得有关已使用资源,已用缓冲区,不同渲染状态上…

Python sqlite3数据库已锁定 - python

我在Windows上使用Python 3和sqlite3。我正在开发一个使用数据库存储联系人的小型应用程序。我注意到,如果应用程序被强制关闭(通过错误或通过任务管理器结束),则会收到sqlite3错误(sqlite3.OperationalError:数据库已锁定)。我想这是因为在应用程序关闭之前,我没有正确关闭数据库连接。我已经试过了: connectio…

python-docx应该在空单元格已满时返回空单元格 - python

我试图遍历文档中的所有表并从中提取文本。作为中间步骤,我只是尝试将文本打印到控制台。我在类似的帖子中已经看过scanny提供的其他代码,但是由于某种原因,它并没有提供我正在解析的文档的预期输出可以在https://www.ontario.ca/laws/regulation/140300中找到该文档from docx import Document from…

Python ThreadPoolExecutor抑制异常 - python

from concurrent.futures import ThreadPoolExecutor, wait, ALL_COMPLETED def div_zero(x): print('In div_zero') return x / 0 with ThreadPoolExecutor(max_workers=4) as execut…

Python:集群作业管理 - python

我在具有两个阶段的计算群集(Slurm)上运行python脚本,它们是顺序的。我编写了两个python脚本,一个用于阶段1,另一个用于阶段2。每天早上,我检查所有第1阶段的工作是否都以视觉方式完成。只有这样,我才开始第二阶段。通过在单个python脚本中组合所有阶段和作业管理,是否有一种更优雅/自动化的方法?我如何知道工作是否完成?工作流程类似于以下内容:w…