将DataTable传递给IronPython

时间:2012-12-05 16:53:15

标签: c# python .net ironpython

我有一个.NET项目,我正在使用IronPython来执行一些数据处理。目前,C#代码循环并为每个需要动态计算的行和列生成IronPython脚本。但是,我想通过传入DataTable对象和一个针对它执行的脚本来提高进程的效率。不幸的是,我收到了'DataTable' object is unsubscriptable错误,并且没有进行任何处理。

用于生成和执行IronPython脚本的C#代码段:

DataTable dt = new DataTable();
dt.Columns.Add("count", typeof(int));
dt.Columns.Add("calc", typeof(int));
dt.Rows.Add(1, null);

ScriptEngine engine = Python.CreateEngine(options);
ScriptScope scope = engine.CreateScope();
scope.SetVariable("dt", dt);
ScriptSource source = engine.CreateScriptSourceFromString(code, SourceCodeKind.AutoDetect);
object result = source.Execute(scope);
DataTable table = scope.GetVariable<System.Data.DataTable>("dt");

要对表执行的Python脚本:

import clr
clr.AddReference('System.Data')
from System import Data
from System.Data import DataTable
for row in dt.Rows:
    dt["calc"] = dt["count"] + 1

如何修复'DataTable' object is unsubscriptable错误,还是有更好的方法来处理将DataTable传递给IronPython?

1 个答案:

答案 0 :(得分:9)

DataTable对象确实 unsubscriptable,即无法通过索引属性访问(即dt[index])。

你可能意味着这个:

for row in dt.Rows:
    row["calc"] = row["count"] + 1

我将dt变量替换为row