----------------------------------------------------.對基礎類型排序
方法一:
調用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>();
this