我收集了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
我有想念吗?
解决方法:
注意:正在修订,因为先前的答案不能正确解决问题.
您正在寻找的被称为“自然顺序”排序.正确执行此操作比以前的解决方案要复杂得多.简而言之,您必须将字符串键分为数字和文本部分,然后按顺序对每个部分进行排序.如果零件是数字状的,请像数字一样对其进行排序.否则,将其排序为字符串.
有关可能的实现,请参见此博客文章Natural Sort Compare with Linq OrderBy.原始来源是here.