C#中Dictionary排序方式

自定義類:ide

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace CSharp中Dictionary排序方式
{
    [Serializable]
    public class CustmonizedClass
    {
        public string stuName { get; set; }

        public int stuAge { get; set; }

        public string stuSex  { get; set; }

        public double stuScore { get; set; }
       
    }
}
View Code


Dictionary<int,自定義類>spa

按照Dictionary的Key值 升序排序(OrderBy)、降序排序(OrderByDescending):3d

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace CSharp中Dictionary排序方式
{
     public  class Program
    {
        static void Main(string[] args)
        {
            CustmonizedClass cn1 = new CustmonizedClass();
            cn1.stuName = "張三";
            cn1.stuAge = 18;
            cn1.stuSex = "";
            cn1.stuScore = 89.5;

            CustmonizedClass cn2 = new CustmonizedClass();
            cn2.stuName = "李四";
            cn2.stuAge = 19;
            cn2.stuSex = "";
            cn2.stuScore = 88.5;


            CustmonizedClass cn3 = new CustmonizedClass();
            cn3.stuName = "王五";
            cn3.stuAge = 17;
            cn3.stuSex = "";
            cn3.stuScore = 89.5;

            Dictionary<int, CustmonizedClass> dic1 = new Dictionary<int, CustmonizedClass>();
            dic1.Add(3, cn1);
            dic1.Add(1, cn2);
            dic1.Add(2, cn3);
            //上面dic1.Add()故意不按照順序

            Dictionary<int, CustmonizedClass> dic1_SortedByKey = dic1.OrderBy(p=>p.Key).ToDictionary(p => p.Key, o => o.Value);
           

            foreach (KeyValuePair<int, CustmonizedClass> item in dic1_SortedByKey) 
            {
                Console.WriteLine("Key:{0} ; Value: name:{1}, age:{2}, sex:{3}, score:{4} ",
                    item.Key,item.Value.stuName,item.Value.stuAge,item.Value.stuSex,item.Value.stuScore);
            }
            Console.ReadLine();                        
        }
    }
}
View Code

Dictionary<int, CustmonizedClass> dic1_SortedByKey = dic1.OrderBy(p=>p.Key).ToDictionary(p => p.Key, o => o.Value);
結果截圖:
code

降序排序:blog

Dictionary<int, CustmonizedClass> dic1_SortedByKey = dic1.OrderByDescending(p => p.Key).ToDictionary(p => p.Key, o => o.Value);排序

結果截圖:get

 

按照Dictionary的Value值的某個屬性 升序排序(OrderBy)、降序排序(OrderByDescending):string

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace CSharp中Dictionary排序方式
{
     public  class Program
    {
        static void Main(string[] args)
        {
            CustmonizedClass cn1 = new CustmonizedClass();
            cn1.stuName = "張三";
            cn1.stuAge = 18;
            cn1.stuSex = "";
            cn1.stuScore = 89.5;

            CustmonizedClass cn2 = new CustmonizedClass();
            cn2.stuName = "李四";
            cn2.stuAge = 19;
            cn2.stuSex = "";
            cn2.stuScore = 88.5;


            CustmonizedClass cn3 = new CustmonizedClass();
            cn3.stuName = "王五";
            cn3.stuAge = 17;
            cn3.stuSex = "";
            cn3.stuScore = 89.5;

            Dictionary<int, CustmonizedClass> dic1 = new Dictionary<int, CustmonizedClass>();
            dic1.Add(3, cn1);
            dic1.Add(1, cn2);
            dic1.Add(2, cn3);
            //上面dic1.Add()故意不按照順序
            //Key升序
            //Dictionary<int, CustmonizedClass> dic1_SortedByKey = dic1.OrderBy(p=>p.Key).ToDictionary(p => p.Key, o => o.Value);
            //Key降序
            //Dictionary<int, CustmonizedClass> dic1_SortedByKey = dic1.OrderByDescending(p => p.Key).ToDictionary(p => p.Key, o => o.Value);
            //Value中stuAge屬性
            Dictionary<int, CustmonizedClass> dic1_SortedByKey = dic1.OrderBy(o => o.Value.stuAge).ToDictionary(p => p.Key, o => o.Value);

            foreach (KeyValuePair<int, CustmonizedClass> item in dic1_SortedByKey) 
            {
                Console.WriteLine("Key:{0} ; Value: name:{1}, age:{2}, sex:{3}, score:{4} ",
                    item.Key,item.Value.stuName,item.Value.stuAge,item.Value.stuSex,item.Value.stuScore);
            }
            Console.ReadLine();                        
        }
    }
}
View Code

關鍵修改這句:it

 Dictionary<int, CustmonizedClass> dic1_SortedByKey = dic1.OrderBy(o => o.Value.stuAge).ToDictionary(p=>p.Key,o=>o.Value);io

結果截圖:

混合排序:相似EXCEL中先按第一列升序、再按第3列的升序……

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace CSharp中Dictionary排序方式
{
     public  class Program
    {
        static void Main(string[] args)
        {
            CustmonizedClass cn1 = new CustmonizedClass();
            cn1.stuName = "張三";
            cn1.stuAge = 18;
            cn1.stuSex = "";
            cn1.stuScore = 89.5;

            CustmonizedClass cn2 = new CustmonizedClass();
            cn2.stuName = "李四";
            cn2.stuAge = 19;
            cn2.stuSex = "";
            cn2.stuScore = 88.5;


            CustmonizedClass cn3 = new CustmonizedClass();
            cn3.stuName = "王五";
            cn3.stuAge = 17;
            cn3.stuSex = "";
            cn3.stuScore = 89.5;

            Dictionary<int, CustmonizedClass> dic1 = new Dictionary<int, CustmonizedClass>();
            dic1.Add(3, cn1);
            dic1.Add(1, cn2);
            dic1.Add(2, cn3);
            //上面dic1.Add()故意不按照順序
            //Key升序
            //Dictionary<int, CustmonizedClass> dic1_SortedByKey = dic1.OrderBy(p=>p.Key).ToDictionary(p => p.Key, o => o.Value);
            //Key降序
            //Dictionary<int, CustmonizedClass> dic1_SortedByKey = dic1.OrderByDescending(p => p.Key).ToDictionary(p => p.Key, o => o.Value);
            //Value中stuAge屬性
            //Dictionary<int, CustmonizedClass> dic1_SortedByKey = dic1.OrderBy(o => o.Value.stuAge).ToDictionary(p => p.Key, o => o.Value);
            //混合排序 等同於下列的linq語句
            //Dictionary<int, CustmonizedClass> dic1_SortedByKey = dic1.OrderBy(o => o.Value.stuScore).ThenByDescending(o=>o.Value.stuAge).ToDictionary(p=>p.Key,o=>o.Value);

            //linq語句
            var dic1_SortedByKey = from n in dic1

                         orderby n.Value.stuScore, n.Value.stuAge descending

                         select n;

            foreach (KeyValuePair<int, CustmonizedClass> item in dic1_SortedByKey) 
            {
                Console.WriteLine("Key:{0} ; Value: name:{1}, age:{2}, sex:{3}, score:{4} ",
                    item.Key,item.Value.stuName,item.Value.stuAge,item.Value.stuSex,item.Value.stuScore);
            }
            Console.ReadLine();                        
        }
    }
}
View Code

Dictionary<int, CustmonizedClass> dic1_SortedByKey = dic1.OrderBy(o => o.Value.stuScore).ThenByDescending(o=>o.Value.stuAge).ToDictionary(p=>p.Key,o=>o.Value);

等同於linq語句:

var dic1_SortedByKey = from n in dic1

                         orderby n.Value.stuScore, n.Value.stuAge descending

                         select n;

結果截圖:

          

相關文章
相關標籤/搜索