如何在Matlab中迭代C#IEnumerable?

Mar*_*rkH 5 .net linq generics ienumerable matlab

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

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

ans = 

John Smith
Run Code Online (Sandbox Code Playgroud)

但是,如果我调用Linq查询返回一个IQueryable集合(实际上是一个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
Run Code Online (Sandbox Code Playgroud)

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

tm1*_*tm1 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));
Run Code Online (Sandbox Code Playgroud)

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

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

NET.addAssembly('System.Core');
Run Code Online (Sandbox Code Playgroud)

为了这个目的.


Stu*_*art 2

我只以相反的方式工作过 Matlab 和 C#(从 C# 调用 Matlab),但在我看来问题在于您的代码中有一个 IQueryable 实例而不是 IEnumerable 。

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


更新 - 因为扩展方法是禁忌...如果您尝试以下操作会发生什么:

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

myEnumerator.MoveNext()
secondItem = myEnumerator.Current
secondItem =
Run Code Online (Sandbox Code Playgroud)