Partager via


Comment : interroger un ArrayList avec LINQ

Lorsque vous utilisez LINQ pour interroger des collections IEnumerable non génériques comme ArrayList, vous devez déclarer explicitement le type de la variable de portée pour répercuter le type spécifique des objets dans la collection. Par exemple, si vous avez un ArrayList d'objets Student, votre clause from (C#) ou From, clause (Visual Basic) doit ressembler à ceci :

// C#
var query = from Student s in arrList
... 
'Visual Basic
Dim query = From student As Student In arrList 
...

En spécifiant le type de la variable de portée, vous effectuez un cast de chaque élément dans le ArrayList en Student.

L'utilisation d'une variable de portée explicitement typée dans une expression de requête équivaut à l'appel de la méthode Cast``1. Cast``1 lève une exception si le cast spécifié ne peut pas être exécuté. Cast``1 et OfType``1 sont les deux méthodes d'opérateurs de requête standard qui s'appliquent aux types IEnumerable non génériques. En Visual Basic, vous devez appeler explicitement la méthode Cast``1 sur la source de données pour garantir l'utilisation d'un type de variable de portée spécifique. Pour plus d'informations, consultezRelations des types dans des opérations de requête (Visual Basic) et Relations des types dans des opérations de requête LINQ (C#).

Exemple

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

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
using System;
using System.Collections;
using System.Linq;

namespace NonGenericLINQ
{
    public class Student
    {
        public string FirstName { get; set; }
        public string LastName { get; set; }
        public int[] Scores { get; set; }
    }

    class Program
    {
        static void Main(string[] args)
        {
            ArrayList arrList = new ArrayList();
            arrList.Add(
                new Student
                    {
                        FirstName = "Svetlana", LastName = "Omelchenko", Scores = new int[] { 98, 92, 81, 60 }
                    });
            arrList.Add(
                new Student
                    {
                        FirstName = "Claire", LastName = "O’Donnell", Scores = new int[] { 75, 84, 91, 39 }
                    });
            arrList.Add(
                new Student
                    {
                        FirstName = "Sven", LastName = "Mortensen", Scores = new int[] { 88, 94, 65, 91 }
                    });
            arrList.Add(
                new Student
                    {
                        FirstName = "Cesar", LastName = "Garcia", Scores = new int[] { 97, 89, 85, 82 }
                    });

            var query = from Student student in arrList
                        where student.Scores[0] > 95
                        select student;

            foreach (Student s in query)
                Console.WriteLine(s.LastName + ": " + s.Scores[0]);

            // Keep the console window open in debug mode.
            Console.WriteLine("Press any key to exit.");
            Console.ReadKey();
        }
    }
}
/* Output: 
    Omelchenko: 98
    Garcia: 97
*/

Voir aussi

Concepts

LINQ to Objects