3

我有KeyValuePair一个value包含我班级之一的通用列表。

因此,对于每个值,我计算一列,并根据该值以表格格式显示它。

但这里我的问题是:对于每个值列表,它包含一行,0作为我通过计算得到的列值。

所以我希望这个价值处于首位。但现在它可以在任何地方。

那么如何根据该计算对其进行排序。

这是我的代码:

 @foreach (KeyValuePair<String, List<MyClass>> keyValuePair in aClient.ESelectionDictionary)
{
    foreach (MyClass eData in keyValuePair.Value)
    {
        string weight;
        ............
        //Here comes some calculations
        ............
        if (weight == 0d)
        {
            addclass = "class=hidden";
        }
        else
        {
            addclass = "class=main";
        }
    }
}

所以这里对于 , 中的所有值eDataweight总是0d除了一个值。

4

2 回答 2

0

添加中间集合,您将在其中按所需顺序获取项目并实现两个循环,第一个将按您要查找的顺序填充集合,第二个循环将呈现表格:

var list = new List<MyClass>(keyValuePair.Value.Count);

foreach (MyClass eData in keyValuePair.Value)
{
    string weight;
    ............
    //Here comes some calculations
    ............
    if (weight == 0d)
    {
        list.Insert(0, eData);
    }
    else
    {
        list.Add(eData);
    }
}

foreach (var eData in list)
    // render eData into table
于 2013-04-05T09:33:34.153 回答
0

根据您的自定义函数排序的列表创建一个新字典,以计算列索引:

var reshuffled = aClient.ESelectionDictionary.ToDictionary(
   kvp => kvp.Key,
   kvp => kvp.Value.OrderBy(CalculateColumnIndex)
);
于 2013-04-05T09:23:59.530 回答