我想使用Linq来查询我项目中的公交时刻表,以便随时能够得到下一个5次公交车到达时间。 如何将查询限制为前5个结果? 数组
更通常地说,我如何在C#中获取一个列表? (在Python中我会使用mylist[:5]
来获取前5个元素。) this
var firstFiveItems = myList.Take(5);
或切片: spa
var secondFiveItems = myList.Skip(5).Take(5);
固然,按照某种顺序获取前五个项目一般很方便: code
var firstFiveArrivals = myList.OrderBy(i => i.ArrivalTime).Take(5);
若是有人有兴趣(即便问题没有要求这个版本),在C#2中将是:(我已经编辑了答案,遵循一些建议) orm
myList.Sort(CLASS_FOR_COMPARER); List<string> fiveElements = myList.GetRange(0, 5);
要得到前5个元素更好地使用这样的表达式: 排序
var firstFiveArrivals = myList.Where([EXPRESSION]).Take(5);
ip
要么 element
var firstFiveArrivals = myList.Where([EXPRESSION]).Take(5).OrderBy([ORDER EXPR]);
get
它将比orderBy变体更快,由于LINQ引擎不会由于执行延迟而扫描全部列表,而且不会对全部数组进行排序。 string
class MyList : IEnumerable<int> { int maxCount = 0; public int RequestCount { get; private set; } public MyList(int maxCount) { this.maxCount = maxCount; } public void Reset() { RequestCount = 0; } #region IEnumerable<int> Members public IEnumerator<int> GetEnumerator() { int i = 0; while (i < maxCount) { RequestCount++; yield return i++; } } #endregion #region IEnumerable Members System.Collections.IEnumerator System.Collections.IEnumerable.GetEnumerator() { throw new NotImplementedException(); } #endregion } class Program { static void Main(string[] args) { var list = new MyList(15); list.Take(5).ToArray(); Console.WriteLine(list.RequestCount); // 5; list.Reset(); list.OrderBy(q => q).Take(5).ToArray(); Console.WriteLine(list.RequestCount); // 15; list.Reset(); list.Where(q => (q & 1) == 0).Take(5).ToArray(); Console.WriteLine(list.RequestCount); // 9; (first 5 odd) list.Reset(); list.Where(q => (q & 1) == 0).Take(5).OrderBy(q => q).ToArray(); Console.WriteLine(list.RequestCount); // 9; (first 5 odd) } }
像pagination
同样,您能够使用下面的公式来获取slice of list or elements
:
var slice = myList.Skip((pageNumber - 1) * pageSize) .Take(pageSize);
例1:前五项
var pageNumber = 1; var pageSize = 5;
示例2:后五项
var pageNumber = 2; var pageSize = 5;
例3:第五项
var pageNumber = 3; var pageSize = 5;
若是注意到formule参数
pageSize = 5
而且pageNumber
正在更改,若是要更改切片中的项目数,则更改pageSize
。