Partager via


Guide pratique pour interroger un arrayList avec LINQ (Visual Basic)

Lorsque vous utilisez LINQ pour interroger des collections non génériques IEnumerable telles que ArrayList, vous devez déclarer explicitement le type de la variable de plage pour refléter le type spécifique des objets de la collection. Par exemple, si vous avez un ArrayList d’objets Student, votre clause from doit ressembler à ceci :

Dim query = From student As Student In arrList
'...

En spécifiant le type de la variable de plage, vous effectuez une conversion de chaque élément dans le ArrayList en un Student.

L’utilisation d’une variable de plage typée explicitement dans une expression de requête équivaut à appeler la Cast méthode. Cast lève une exception si le cast spécifié ne peut pas être effectué. Cast et OfType sont les deux méthodes d’opérateur de requête standard qui fonctionnent sur des types non génériques IEnumerable . Dans Visual Basic, vous devez appeler explicitement la Cast méthode sur la source de données pour garantir un type de variable de plage spécifique. Pour plus d’informations, consultez Relations de type dans les opérations de requête (Visual Basic).

Exemple :

L’exemple suivant montre une requête simple sur un ArrayList. Notez que cet exemple utilise des initialiseurs d’objet lorsque le code appelle la Add méthode, mais ce n’est pas une exigence.

Imports System.Collections
Imports System.Linq

Module Module1

    Public Class Student
        Public Property FirstName As String
        Public Property LastName As String
        Public Property Scores As Integer()
    End Class

    Sub Main()

        Dim student1 As New Student With {.FirstName = "Svetlana",
                                     .LastName = "Omelchenko",
                                     .Scores = New Integer() {98, 92, 81, 60}}
        Dim student2 As New Student With {.FirstName = "Claire",
                                    .LastName = "O'Donnell",
                                    .Scores = New Integer() {75, 84, 91, 39}}
        Dim student3 As New Student With {.FirstName = "Cesar",
                                    .LastName = "Garcia",
                                    .Scores = New Integer() {97, 89, 85, 82}}
        Dim student4 As New Student With {.FirstName = "Sven",
                                    .LastName = "Mortensen",
                                    .Scores = New Integer() {88, 94, 65, 91}}

        Dim arrList As New ArrayList()
        arrList.Add(student1)
        arrList.Add(student2)
        arrList.Add(student3)
        arrList.Add(student4)

        ' Use an explicit type for non-generic collections
        Dim query = From student As Student In arrList
                    Where student.Scores(0) > 95
                    Select student

        For Each student As Student In query
            Console.WriteLine(student.LastName & ": " & student.Scores(0))
        Next
        ' Keep the console window open in debug mode.
        Console.WriteLine("Press any key to exit.")
        Console.ReadKey()
    End Sub

End Module
' Output:
'   Omelchenko: 98
'   Garcia: 97

Voir aussi