如何排序列表?

时间:2010-06-23 17:32:41

标签: linq list

好的,我有一个列表,我想排序。首先,一些代码:

    foreach (var Row in Result)
    {
        foreach (var RowAll in Row.All)
        {
            DataObject.Add(new List<string>() { RowAll.Value1, RowAll.Value2, RowAll.Value3});
            break; 
        }
    }

现在我想按每个子列表的Value2对父列表进行排序。 这可能吗?如果是这样,我该怎么做?

2 个答案:

答案 0 :(得分:12)

您可以通过LINQ:

执行此操作
 // I'm assuming here that "LastCheckin" is defined as List<List<string>> or similar
 // ...

 var sorted = Data.LastCheckin.OrderBy(list => list[1]);

这将返回一个IEnumerable<List<string>>,其中包含按“子列表”(Value2)中的第二个值排序的“列表”。


如果您想对列表进行排序,可以改为使用List<T>.Sort

 Data.LastCheckin.Sort( (a,b) => a[1].CompareTo(b[1]) );

如果您需要在运行时指定升序或降序,则可以通过以下方式轻松处理:

 bool ascending = true; // Set to false for decending

 int mult = ascending ? 1 : -1;
 Data.LastCheckin.Sort( (a,b) => mult * a[1].CompareTo(b[1]) );

为了处理更复杂的检查,您可以将lambda分成多行:

 bool ascending = true; // Set to false for decending
 string myDateFormat = GetDateFormat(); // Specify date format

 int mult = ascending ? 1 : -1;
 Data.LastCheckin.Sort( (aStr,bStr) => 
    {
        DateTime a, b;
        bool aSuccess = DateTime.TryParseExact(aStr[1], myDateFormat, DateTimeStyles.None, CultureInfo.InvariantCulture, out a);
        bool bSuccess = DateTime.TryParseExact(bStr[1], myDateFormat, DateTimeStyles.None, CultureInfo.InvariantCulture, out b);

        int result;
        if (!aSuccess)
            result = bSuccess ? -1 : 0;
        else if (!bSuccess)
            result = 1;
        else
            result = a.CompareTo(b);

        return mult * result;

    });

它处理a和b上的解析器失败,并且应该将它们放在排序的末尾。

答案 1 :(得分:1)

我设法让这个工作:

listOfLists = listOfLists.OrderByDescending(a => a.Max(x => x.paramToSoryBy)).ToList();