61

我有一个乘客(对象)列表,其中有不同的属性..

passenger.name
passenger.age
passenger.surname

我想按年龄标准对这个列表进行排序,我该怎么做?

我知道在整数/字符串列表中 List.Sort() 有效,但如果是对象列表,我不知道它是否可以按对象属性的值排序!

谢谢。

4

4 回答 4

142

要按对象中的属性排序,您必须指定比较器或方法来获取该属性。

使用List.Sort方法:

theList.Sort(Function(x, y) x.age.CompareTo(y.age))

使用OrderBy扩展方法:

theList = theList.OrderBy(Function(x) x.age).ToList()
于 2012-07-31T08:26:12.180 回答
5

如果您需要自定义字符串排序,您可以创建一个函数,该函数根据您指定的顺序返回一个数字。

例如,我有一些照片,我想根据正面或扣环进行分类。所以我做了以下事情:

Private Function sortpictures(s As String) As Integer
    If Regex.IsMatch(s, "FRONT") Then
        Return 0
    ElseIf Regex.IsMatch(s, "SIDE") Then
        Return 1
    ElseIf Regex.IsMatch(s, "CLASP") Then
        Return 2
    Else
        Return 3
    End If
End Function

然后我这样调用排序函数:

list.Sort(Function(elA As String, elB As String)
                  Return sortpictures(elA).CompareTo(sortpictures(elB))
              End Function)
于 2016-12-15T17:39:58.550 回答
0

您必须实现 IComparer 接口。

在这个示例中,我有我的自定义对象 JSONReturn,我像这样实现我的类:

Friend Class JSONReturnComparer
    Implements IComparer(of JSONReturn)

    Public Function Compare(x As JSONReturn, y As JSONReturn) As Integer Implements    IComparer(Of JSONReturn).Compare
        Return String.Compare(x.Name, y.Name)
    End Function

End Class

我这样称呼我的排序列表方法:alResult.Sort(new JSONReturnComparer())

也许它可以帮助你

于 2014-01-22T10:40:21.987 回答
0

尝试..

Dim sortedList = From entry In mylist Order By entry.name Ascending Select entry

mylist = sortedList.ToList

于 2020-10-26T12:22:49.110 回答