如何在Matlab中迭代C#IEnumerable?

时间:2011-06-17 16:18:33

标签: .net linq generics matlab ienumerable

我在C#中有一些Linq to SQL代码,我试图使用Matlab 2010b访问它。如果我的Linq代码返回单个项目实例,我可以在Matlab中无问题地访问所有属性:

dal = Data.PeopleRepository
person = dal.QueryPersonById(1)
person.Name

ans = 

John Smith

但是,如果我调用一个返回IQueryable集合的Linq查询(实际上是一个System.Data.Linq.Table类),我很难找到里面的Person实例列表!

people = dal.QueryAllPeople()

people = 

System.Data.Linq.Table<Data.Person> handle
Package: System.Data.Linq
Properties:
   Context: [1x1 Data.PeopleRepository]
   IsReadOnly: 0

我尝试过在人们身上使用GetEnumerator方法转换为IEnumerable,但我仍然无法获取内部的实际Person实例。 (我知道由于后期评估,实际上可能还没有从数据库中检索到这些值!Aarggh!)任何指针都表示赞赏,如果不清楚则道歉 - 这是我的第一个StackOverflow问题......

2 个答案:

答案 0 :(得分:8)

今天遇到了类似的挑战。确实可以调用扩展方法。但是,语法有点笨拙。

为了枚举,IEnumerable.ToArray()扩展方法很方便。对于扩展方法,您需要知道它们的定义位置。在这种情况下,方法的完整签名是System.Linq.Enumerable.ToArray<T>(this IEnumerable<T>)。 Matlab不关心this修饰符。但是,因为它是泛型方法,所以不能在Matlab中直接使用它。相反,需要NET.invokeGeneric方法。

以下示例枚举双精度数并将结果转换为Matlab数组。

ret = double(NET.invokeGenericMethod('System.Linq.Enumerable', 'ToArray', ...
   {'System.Double'}, enumerableInstance));

IQueryable<T> : IEnumerable<T>开始,同样的方法(ToArray())应该可以完成你的工作。省略转换为Matlab双数组,并指定正确的元素类型(我想是Data.Person)。

为了访问静态Enumerable类,Matlab需要加载.NET 3.0库。添加

NET.addAssembly('System.Core');

为此目的。

答案 1 :(得分:2)

我只是用Matlab和C#相反(从C#调用Matlab)但我觉得问题是你的代码中有一个IQueryable实例而不是IEnumerable。

尝试调用people = dal.QueryAllPeople().ToList()people = dal.QueryAllPeople.ToArray() - 这些将导致执行查询 - 然后希望数据在Matlab中可用。


更新 - 因为扩展方法是禁止的......如果你尝试会发生什么:

myEnumerator = dal.QueryAllPeople().GetEnumerator()
myEnumerator.MoveNext()
firstItem = myEnumerator.Current
firstItem =

myEnumerator.MoveNext()
secondItem = myEnumerator.Current
secondItem =