我正在使用以下代码向字典添加信息:
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
答案 0 :(得分:7)
嗯,你当然可以轻松地按顺序获得钥匙:
var ordered = from k in dictionary.Keys orderby k select k;
甚至更简单:
var ordered = dictionary.Keys.OrderBy(x => x);
请注意,您不应该按照添加它们的顺序依赖存储对的字典 - 基本上您不应该假设任何排序。字典。