我收集了SortedDictionary
:
SortedDictionary<string, string> _variableValues = new SortedDictionary<string, string>();
键值对如下所示:
ThkPost_Point15 5
ThkPost_Point1 15
ThkPost_Point11 8
ThkPost_Point2 7
ThkPost_Point20 1
ThkPost_Point22 1
现在我想按字母顺序对它们进行排序。
我尝试使用
执行此操作_variableValues.OrderBy(key => key.Key);
但我的问题是结果是:
ThkPost_Point1 15
ThkPost_Point11 8
ThkPost_Point15 5
ThkPost_Point2 7
ThkPost_Point20 1
ThkPost_Point22 1
但我正在寻找的是一种解决方案来实现类似的排序结果:
ThkPost_Point1 15
ThkPost_Point2 7
ThkPost_Point11 8
ThkPost_Point15 5
ThkPost_Point20 1
ThkPost_Point22 1
有没有办法使用SortedDictionary
以这种方式对数据进行排序?
编辑:
我试图实现Babu和metacubed的提示。
因此以下列方式强迫它
static void Main(string[] args)
{
SortedDictionary<string, string> _varVal = new SortedDictionary<string, string>(StringComparer.OrdinalIgnoreCase);
_varVal.Add("Variable1", "Value1");
_varVal.Add("Variable2", "Value2");
_varVal.Add("Variable3", "Value3");
_varVal.Add("Variable4", "Value4");
_varVal.Add("Variable5", "Value5");
_varVal.Add("Variable10", "Value10");
_varVal.Add("Variable11", "Value11");
_varVal.Add("Variable12", "Value12");
_varVal.Add("Variable13", "Value13");
_varVal.Add("Variable14", "Value14");
_varVal.Add("Variable20", "Value20");
_varVal.Add("Variable22", "Value21");
_varVal.Add("Variable23", "Value22");
_varVal.Add("Variable24", "Value23");
_varVal.Add("Variable25", "Value24");
foreach (KeyValuePair<string, string> kvp in _varVal)
{
Console.WriteLine(kvp.Key,kvp.Value);
Debug.WriteLine(kvp.Key +" "+ kvp.Value);
}
Application.Run();
}
但结果仍然如下:
Variable1 Value1
Variable10 Value10
Variable11 Value11
Variable12 Value12
Variable13 Value13
Variable14 Value14
Variable2 Value2
Variable20 Value20
Variable22 Value21
Variable23 Value22
Variable24 Value23
Variable25 Value24
Variable3 Value3
Variable4 Value4
Variable5 Value5
我错过了什么吗?
答案 0 :(得分:3)
注意:修改是因为前面的答案没有正确解决问题。
您正在寻找的是“自然顺序”排序。与早期的解决方案相比,这样做要复杂得多。简而言之,您必须将字符串键拆分为其数字和文本部分,然后按顺序对每个部分进行排序。如果部件类似于数字,则将其排序为数字。否则,将其排序为字符串。
有关可能的实施,请参阅此博文Natural Sort Compare with Linq OrderBy。原始来源为here。