如何对Dictionary的值进行排序
在实际开发中遇到一个比较麻烦的问题,由于数据的不规则性,所以存储在Dictionary中,这里就有个麻烦了,如果要按照字典中的值进行排序办呢。这里就把解决办法写出来。用到的是Array的Sort方法。
一、首先说下Array的Sort方法,该方法有很多实现,我们要用到的就是 public static void Sort<TKey, TValue>(TKey[] keys, TValue[] items);这个方法,这个方法有个好处就是会按照第一个数组进行排序,而对应的第二个数组会进行相应的位置变化,可能大家还会感觉有点不理解,下面举实例。直接上代码
class Program
{
static void Main(string[] args)
{
Dictionary<string, int> dic = new Dictionary<string, int>();
dic.Add("1", 300);
dic.Add("2", 200);
dic.Add("333", 10);
dic.Add("4", 40);
dic.Add("5", 200);
Sort(ref dic);
Console.Read();
}
public static void Sort(ref Dictionary<string, int> dic)
{
string[] arrayName = new string[dic.Count];
int[] arrayValue = new int[dic.Count];
dic.Keys.CopyTo(arrayName, 0);
dic.Values.CopyTo(arrayValue, 0);
Array.Sort(arrayValue, arrayName);//会根据arrayValue的值进行升序排序,arrayName对应的会进行位置调整
Array.Reverse(arrayValue);//这是为了降序
Array.Reverse(arrayName);
IDictionary<string, int> dicSorted = new Dictionary<string, int>();
for (int i = 0; i < arrayName.Length; i++)
{
dicSorted.Add(arrayName[i], dic[arrayName[i]]);
}
}
}
{
static void Main(string[] args)
{
Dictionary<string, int> dic = new Dictionary<string, int>();
dic.Add("1", 300);
dic.Add("2", 200);
dic.Add("333", 10);
dic.Add("4", 40);
dic.Add("5", 200);
Sort(ref dic);
Console.Read();
}
public static void Sort(ref Dictionary<string, int> dic)
{
string[] arrayName = new string[dic.Count];
int[] arrayValue = new int[dic.Count];
dic.Keys.CopyTo(arrayName, 0);
dic.Values.CopyTo(arrayValue, 0);
Array.Sort(arrayValue, arrayName);//会根据arrayValue的值进行升序排序,arrayName对应的会进行位置调整
Array.Reverse(arrayValue);//这是为了降序
Array.Reverse(arrayName);
IDictionary<string, int> dicSorted = new Dictionary<string, int>();
for (int i = 0; i < arrayName.Length; i++)
{
dicSorted.Add(arrayName[i], dic[arrayName[i]]);
}
}
}
上面的结果就是
300 1
200 2
200 5
40 4
10 333
这样就根据字典的值进行相应的排序了