----------------------------------------------------.对基础类型排序
方法一:
调用sort方法,如果需要降序,进行反转:
List<int> list = new List<int>();
list.Sort();// 升序排序
list.Reverse();// 反转顺序
方法二:
使用lambda表达式,在前面加个负号就是降序了
List<int> list= new List<int>(){5,1,22,11,4};
list.Sort((x, y) => x.CompareTo(y));//升序
list.Sort((x, y) => -x.CompareTo(y));//降序
-------------------------------------------------------------对非基础类型排序
方法一:
修改类本身,实现IComparable<T>接口
//重写的CompareTo方法,根据Id排序
public int CompareTo(People other)
{
if (null == other)
{
return 1;//空值比较大,返回1
}
//return this.Id.CompareTo(other.Id);//升序
return other.Id.CompareTo(this.Id);//降序
}
方法二:
委托
list.Sort(delegate(People p1,People p2)
{
return p1.Id.CompareTo(p2.Id);//升序
});
lambda
list.Sort((x,y)=> { return x.Id.CompareTo(y.Id); });
-------------------------------------------------------------OrderBy
list = list.OrderBy(o => o.Id).ToList();//升序
list = list.OrderByDescending(o => o.Id).ToList();//降序
list = list.OrderBy(o => o.Id).ThenBy(o=>o.Name).ToList();
list = list.OrderByDescending(o => o.Id).ThenByDescending(o=>o.Name).ToList();//降序
---------------------------------------------------------------------------linq 去重
var list_distinct = list.GroupBy(a => new { a.name1, a.name2, a.name3 }).Select(a => a.Key).ToList();
------------------------------------------------------linq 查询金额最高前几条
//
List<ListSortModel> sortedList = (from a in list orderby a.Amount descending select a).Take(data.AmountCount).ToList();
-----------------------------linq取DataTable某一列数据返回给一个List<int>
var list =dt.AsEnumerable().Select<DataRow, int>(x => Convert.ToInt32(x["列名"])).ToList<int>();
原文地址:https://www.cnblogs.com/j2ee-web-01/p/10346173.html