订购字典

时间:2011-08-30 20:41:44

标签: c# sorting dictionary duplicates

我正在使用以下代码向字典添加信息:

foreach (string word in lineList)
{
    if (dictionary.ContainsKey(word))
        dictionary[word]++;
    else
        dictionary[word] = 1;
}

// I believe this is what needs to change..?
var ordered = from k in dictionary.Keys select k;

当我使用StreamWriter打印出来的行时,它会按照添加到dictionary的顺序将其打印出来。

我要做的是按照首先比较PartDescription然后PartNumber的顺序打印出来,然后以数字方式打印出来。

文件看起来像这样:

PartDescription        PartNumber        Name        X        Y        Rotation
1608RTANT              147430            J1        20.555   -12.121       180
TANTD                  148966            J2        20.555   -12.121       270
SOMETHING              148966            R111      20.555   -12.121       360
SOMETHING              148966            C121      20.555   -12.121       180
SOMETHING              148966            R50       205.555  -12.121       180
SOMETHING              148966            R51      -205.555  125.121       270
SOMETHING              148966            R52       20.555   -12.121       0
SOMETHING              148966            C12       20.555   -12.121       0
1709RTANT              147430            C98       20.555   -12.121       0
1608RTANT              147429            QD1       20.555   -12.121       180
1709RTANT              147430            F12       20.555   -12.121       0
1609RTANT              147445            P9        20.555   -12.121       180

StreamWriter会输出如下:

1, 1608RTANT, 147429, 1   //Line#, PartDescription, PartNumber, # of Duplicates (from dictionary key)
2, 1608RTANT, 147430, 1
3, 1609RTANT, 147445, 1
4, 1709RTANT, 147430, 2
5, SOMETHING, 148966, 6
6, TANTD, 148966, 1

1 个答案:

答案 0 :(得分:7)

嗯,你当然可以轻松地按顺序获得钥匙:

var ordered = from k in dictionary.Keys orderby k select k;

甚至更简单:

var ordered = dictionary.Keys.OrderBy(x => x);

请注意,您不应该按照添加它们的顺序依赖存储对的字典 - 基本上您不应该假设任何排序。字典。

相关问题