在LINQ中使用DataGridViewRowCollection对象
我想使用扩展方法和lambda表达式在LINQ表达式中使用DataGridViewRowCollection
。 不幸的是,扩展方法适用于IEnumerable
类型, DataGridViewRowCollection
没有实现。 有趣的是,我可以在这里使用类似SQL的语法LINQ:
IEnumerable lRows = from DataGridViewRow row in dgvGrid.Rows select row;
在这之后,我可以使用LINQ扩展方法:
foreach (DataGridViewRow lRow in lRows.Where(row => row.index > 4)) { ... }
有没有什么办法可以将我的DataGridViewRowCollection
转换为IEnumerable
而不使用那个长的第一个语句? 同样的事情适用于DataGridViewCellCollection
和DataGridViewColumnCollection
。
PS。 我正在使用.net framework 3.5
是的,这样做:
var rows = yourDataGridViewRowCollection .Cast() .Where(row => row.index > 4);
这使用Enumerable.Cast
扩展方法:
Cast
方法允许通过提供必要的类型信息在非generics集合上调用标准查询运算符。 例如,(IEnumerable) ArrayList
不实现IEnumerable
,但通过在ArrayList
对象上调用Cast
,可以使用标准查询运算符来查询序列。(IEnumerable)