C# 对具有相同类型的不同属性重新使用 LINQ 表达式

标签 c# linq

我有一个类(class)有几个 int属性:

class Foo
{
    string bar {get; set;}
    int a {get; set;}
    int b {get; set;}    
    int c {get; set;}
}

我有一个 LINQ 表达式,我希望在 List<Foo> 上使用.我希望能够使用此表达式通过查看三个属性中的任何一个来从列表中过滤/选择。例如,如果我按 a 过滤:

return listOfFoo.Where(f => f.a >= 0).OrderBy(f => f.a).Take(5).Select(f => f.bar);

但是,我希望能够使用 f.a 中的任何一个来做到这一点。 , f.b , 或 f.c .我不想重新键入 LINQ 表达式 3 次,而是希望有一些方法可以使用一个参数来指定我要过滤的 a、b 或 c 中的哪一个,然后返回该结果。

有没有办法在 C# 中做到这一点?没有立即想到,但感觉应该是可能的。

最佳答案

IEnumerable<string> TakeBarWherePositive(IEnumerable<Foo> sequenceOfFoo, Func<Foo, int> intSelector) {
  return sequenceOfFoo
            .Where(f => intSelector(f) >= 0)
            .OrderBy(intSelector)
            .Take(5)
            .Select(f => f.bar);
}

然后你会调用

var a = TakeBarWherePositive(listOfFoo, f => f.a);
var b = TakeBarWherePositive(listOfFoo, f => f.b);

关于C# 对具有相同类型的不同属性重新使用 LINQ 表达式,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45134096/

相关文章:

c# - 从 Dictionary<string,object> 初始化类型为 T 的对象

c# - 这在 C# 或 LINQ 中意味着什么? - ( () => )

c# - SyncFusion GridDataBoundGrid 数据绑定(bind)问题

c# - 无效字符错误SQL,OracleDataReader

c# - 如何在 Monodevelop 中使用 OpenTK GLWidget 进行渲染?

c# - 包含项目对的匹配项

c# - 将我的 SQL 查询转换为 c# linq/lambda。多参数GroupBy

c# - 用 linq 替换两个 foreach 循环

c# - 基于每个元素调试 LINQ

c# - 如何以表格格式显示 SQL 数据库