c# – Linq to objects Predicate Builder

使用 linq到对象(不是 linq到sql)进行条件查询的最佳方法是什么.

目前我正在使用http://www.albahari.com/nutshell/predicatebuilder.aspx中的Predicate构建器
并将已编译的谓词传递给IEnumerable.Where,它似乎运行良好.

我要解决的示例代码:

我有这个

string keyword1 = "Test1";
 string keyword2 = "Test3";

        IEnumerable<TestObject> tests = new List<TestObject>()
                                     {
                                         new TestObject() {Name1 = "Test1",Name2 = "Test1"},new TestObject() {Name1 = "Test2",Name2 = "Test2"},new TestObject() {Name1 = "Test3",Name2 = "Test3"},};

        if (!String.IsNullOrEmpty(keyword1) && String.IsNullOrEmpty(keyword2))
            tests = tests.Where(e => e.Name1.Contains(keyword1));
        else if (!String.IsNullOrEmpty(keyword2) && !String.IsNullOrEmpty(keyword1))
            tests = tests.Where(e => e.Name2.Contains(keyword2) || e.Name1.Contains(keyword1));

        return tests.ToList();

解决方法

只需将PredicateBuilder更改为使用委托而不是表达式树,并使用lambdas构建结果:
public static class DelegatePredicateBuilder
{
  public static Func<T,bool> True<T>()  { return f => true;  }
  public static Func<T,bool> False<T>() { return f => false; }

  public static Func<T,bool> Or<T>(this Func<T,bool> expr1,Func<T,bool> expr2)
  {
      return t => expr1(t) || expr2(t);
  }

  public static Func<T,bool> And<T>(this Func<T,bool> expr2)
  {
      return t => expr1(t) && expr2(t);
  }
}

相关文章

目录简介使用JS互操作使用ClipLazor库创建项目使用方法简单测...
目录简介快速入门安装 NuGet 包实体类User数据库类DbFactory...
本文实现一个简单的配置类,原理比较简单,适用于一些小型项...
C#中Description特性主要用于枚举和属性,方法比较简单,记录...
[TOC] # 原理简介 本文参考[C#/WPF/WinForm/程序实现软件开机...
目录简介获取 HTML 文档解析 HTML 文档测试补充:使用 CSS 选...