C#根据日期范围过滤IQueryable<T>集合
2023-09-11 14:16:51 时间
需要扩展IQueryable<T>,参数包括一个DateTime类型的属性、开始日期、截止日期。
public static class MyExtension { public static IQueryable<T> WhereDateRange<T>(this IQueryable<T> source, Expression<Func<T, DateTime>> getter, DateTime from, DateTime to) { Expression body = getter.Body; var predicate = Expression.Lambda<Func<T, bool>>( Expression.And(Expression.GreaterThanOrEqual(body, Expression.Constant(from)),Expression.LessThanOrEqual(body, Expression.Constant(to))), getter.Parameters ); return source.Where(predicate); } }
现在可以筛选满足某个日期范围内的集合。比如:
class Program { static void Main(string[] args) { IEnumerable<Pet> pets = new List<Pet> { new Pet {Id=1,Birthday=new DateTime(2014,1,2) }, new Pet {Id=2,Birthday=new DateTime(2015,1,2) }, new Pet {Id=1,Birthday=new DateTime(2016,1,2) } }; var query = pets.AsQueryable().WhereDateRange<Pet>(t => t.Birthday,DateTime.Now.AddYears(-2), DateTime.Now.AddYears(-1)); foreach(var item in query) { Console.WriteLine(item.Birthday.ToShortDateString()); } } } public class Pet { public int Id { get; set; } public DateTime Birthday { get; set; } }
相关文章
- [C#] 使用 dnSpy 反编译
- 在C#中使用Irony实现SQL语句的解析
- C#里事件和委托有什么区别啊
- C#中毫米与像素的换算方法
- C#日期格式化
- c#中@标志的作用 C#通过序列化实现深表复制 细说并发编程-TPL 大数据量下DataTable To List效率对比 【转载】C#工具类:实现文件操作File的工具类 异步多线程 Async .net 多线程 Thread ThreadPool Task .Net 反射学习
- c#代码 天气接口 一分钟搞懂你的博客为什么没人看 看完python这段爬虫代码,java流泪了c#沉默了 图片二进制转换与存入数据库相关 C#7.0--引用返回值和引用局部变量 JS直接调用C#后台方法(ajax调用) Linq To Json SqlServer 递归查询
- SQL 横转竖 、竖专横 (转载) 使用Dapper.Contrib 开发.net core程序,兼容多种数据库 C# 读取PDF多级书签 Json.net日期格式化设置 ASPNET 下载共享文件 ASPNET 文件批量下载 递归,循环,尾递归 利用IDisposable接口构建包含非托管资源对象 《.NET 进阶指南》读书笔记2------定义不可改变类型
- 腾讯云图片鉴黄集成到C# SQL Server 怎么在分页获取数据的同时获取到总记录数 sqlserver 操作数据表语句模板 .NET MVC后台发送post请求 百度api查询多个地址的经纬度的问题 try{}里有一个 return 语句,那么紧跟在这个 try 后的 finally {}里的 code 会 不会被执行,什么时候被执行,在 return 前还是后? js获取某个日期
- C#字符串数组排序 C#排序算法大全 C#字符串比较方法 一个.NET通用JSON解析/构建类的实现(c#) C#处理Json文件 asp.net使用Jquery+iframe传值问题
- C# IL DASM 使用-破解c#软件方法
- 【卷土重来之C#学习笔记】(二)c#编程概述
- Word控件Spire.Doc 转换教程(二十七):如何在 C# 中将 Word 转换为 PostScript
- Word处理控件Aspose.Words功能演示:从 C# 中的 Word 文档中提取图像
- C# (初入江湖) -属性&索引&命名空间&using
- C#封装C++DLL(特别是char*对应的string)
- C#日期格式大全
- C#泛型案例与教程
- C#中对xml数据的读取和写入
- C#+MapServer相关代码
- C#日期格式化
- C# string格式的日期时间字符串转为DateTime类型的方法
- C#与.NET Framework c#编程语言,和java是一样的。(c#,java) -->javaweb,asp.net