Aracılığıyla paylaş


Nasıl yapılır: Farklı Dosyalardan İçerik Birleştirme (LINQ)

Bu örnekte eşleşen anahtar olarak kullanılan ortak bir değeri paylaşan iki virgülle sınırlanmış dosya verileri nasıl gösterir.Bu teknik, iki elektronik tablo verileri birleştirmek varsa veya bir elektronik tablodan ve bir dosyadan yeni bir dosyaya başka bir biçime sahip kullanışlı olabilir.Herhangi bir tür yapısal metin ile çalışmak için örnek değişiklik yapabilirsiniz.

Veri dosyaları oluşturmak için

  1. Scores.csv adlı bir dosyaya aşağıdaki satırları kopyalayın ve proje dosyanızla aynı klasöre kaydedin.Örneğin, proje dosyanızı Visual Studio 2010\Projects ise, scores.csv bu klasöre kaydedin.Dosya, elektronik tablo verilerini temsil eder.Öğrenci kimliği sütun 1 ve sütun 2'den 5 test puanlarının olan.

    111, 97, 92, 81, 60
    112, 75, 84, 91, 39
    113, 88, 94, 65, 91
    114, 97, 89, 85, 82
    115, 35, 72, 91, 70
    116, 99, 86, 90, 94
    117, 93, 92, 80, 87
    118, 92, 90, 83, 78
    119, 68, 79, 88, 92
    120, 99, 82, 81, 79
    121, 96, 85, 91, 60
    122, 94, 92, 91, 91
    
  2. Names.csv adlı bir dosyaya aşağıdaki satırları kopyalayın ve proje dosyanızla aynı klasöre kaydedin.Örneğin, proje dosyanızı Visual Studio 2010\Projects ise, names.csv bu klasöre kaydedin.Öğrencinin Soyadı, ilk ad ve Öğrenci kimliği içeren bir elektronik tablo dosyasını temsil

    Omelchenko,Svetlana,111
    O'Donnell,Claire,112
    Mortensen,Sven,113
    Garcia,Cesar,114
    Garcia,Debra,115
    Fakhouri,Fadi,116
    Feng,Hanying,117
    Garcia,Hugo,118
    Tucker,Lance,119
    Adams,Terry,120
    Zabokritski,Eugene,121
    Tucker,Michael,122
    

Örnek

Class JoinStrings

    Shared Sub Main()

        ' Join content from spreadsheet files that contain 
        ' related information. names.csv contains the student name 
        ' plus an ID number. scores.csv contains the ID and a  
        ' set of four test scores. The following query joins 
        ' the scores to the student names by using ID as a 
        ' matching key. 

        Dim names As String() = System.IO.File.ReadAllLines("../../../names.csv")
        Dim scores As String() = System.IO.File.ReadAllLines("../../../scores.csv")

        ' Name:    Last[0],       First[1],  ID[2],     Grade Level[3] 
        '          Omelchenko,    Svetlana,  111,       2 
        ' Score:   StudentID[0],  Exam1[1]   Exam2[2],  Exam3[3],  Exam4[4] 
        '          111,           97,        92,        81,        60 

        ' This query joins two dissimilar spreadsheets based on common ID value. 
        ' Multiple from clauses are used instead of a join clause 
        ' in order to store results of id.Split. 
        Dim scoreQuery1 = From name In names 
                         Let n = name.Split(New Char() {","}) 
                            From id In scores 
                            Let n2 = id.Split(New Char() {","}) 
                            Where n(2) = n2(0) 
                            Select n(0) & "," & n(1) & "," & n2(0) & "," & n2(1) & "," &
                              n2(2) & "," & n2(3)

        ' Pass a query variable to a Sub and execute it there. 
        ' The query itself is unchanged.
        OutputQueryResults(scoreQuery1, "Merge two spreadsheets:")

        ' Keep console window open in debug mode.
        Console.WriteLine("Press any key to exit.")
        Console.ReadKey()
    End Sub 

    Shared Sub OutputQueryResults(ByVal query As IEnumerable(Of String), ByVal message As String)

        Console.WriteLine(System.Environment.NewLine & message)
        For Each item As String In query
            Console.WriteLine(item)
        Next
        Console.WriteLine(query.Count & " total names in list")

    End Sub 
End Class 
' Output: 
'Merge two spreadsheets: 
'Adams,Terry,120, 99, 82, 81 
'Fakhouri,Fadi,116, 99, 86, 90 
'Feng,Hanying,117, 93, 92, 80 
'Garcia,Cesar,114, 97, 89, 85 
'Garcia,Debra,115, 35, 72, 91 
'Garcia,Hugo,118, 92, 90, 83 
'Mortensen,Sven,113, 88, 94, 65 
'O'Donnell,Claire,112, 75, 84, 91 
'Omelchenko,Svetlana,111, 97, 92, 81 
'Tucker,Lance,119, 68, 79, 88 
'Tucker,Michael,122, 94, 92, 91 
'Zabokritski,Eugene,121, 96, 85, 91 
'12 total names in list
class JoinStrings
{
    static void Main()
    {
        // Join content from dissimilar files that contain 
        // related information. File names.csv contains the student 
        // name plus an ID number. File scores.csv contains the ID  
        // and a set of four test scores. The following query joins 
        // the scores to the student names by using ID as a 
        // matching key. 

        string[] names = System.IO.File.ReadAllLines(@"../../../names.csv");
        string[] scores = System.IO.File.ReadAllLines(@"../../../scores.csv");


        // Name:    Last[0],       First[1],  ID[2] 
        //          Omelchenko,    Svetlana,  11 
        // Score:   StudentID[0],  Exam1[1]   Exam2[2],  Exam3[3],  Exam4[4] 
        //          111,           97,        92,        81,        60 

        // This query joins two dissimilar spreadsheets based on common ID value. 
        // Multiple from clauses are used instead of a join clause 
        // in order to store results of id.Split.
        IEnumerable<string> scoreQuery1 =
            from name in names
            let nameFields = name.Split(',')
            from id in scores
            let scoreFields = id.Split(',')
            where nameFields[2] == scoreFields[0]
            select nameFields[0] + "," + scoreFields[1] + "," + scoreFields[2] 
                   + "," + scoreFields[3] + "," + scoreFields[4];

        // Pass a query variable to a method and execute it 
        // in the method. The query itself is unchanged.
        OutputQueryResults(scoreQuery1, "Merge two spreadsheets:");

        // Keep console window open in debug mode.
        Console.WriteLine("Press any key to exit");
        Console.ReadKey();
    }

    static void OutputQueryResults(IEnumerable<string> query, string message)
    {
        Console.WriteLine(System.Environment.NewLine + message);
        foreach (string item in query)
        {
            Console.WriteLine(item);
        }
        Console.WriteLine("{0} total names in list", query.Count());
    }
}
/* Output:
Merge two spreadsheets:
Adams, 99, 82, 81, 79
Fakhouri, 99, 86, 90, 94
Feng, 93, 92, 80, 87
Garcia, 97, 89, 85, 82
Garcia, 35, 72, 91, 70
Garcia, 92, 90, 83, 78
Mortensen, 88, 94, 65, 91
O'Donnell, 75, 84, 91, 39
Omelchenko, 97, 92, 81, 60
Tucker, 68, 79, 88, 92
Tucker, 94, 92, 91, 91
Zabokritski, 96, 85, 91, 60
12 total names in list
 */

Kod Derleniyor

  • Oluşturma bir Visual Studio hedefleyen proje .NET Framework sürüm 3.5 veya sonraki bir sürümü.Varsayılan olarak, proje başvuru System.Core.dll sahiptir ve bir using yönergesi (C#) veya Imports deyimi (Visual Basic) System.Linq ad alanı.C# projeleri, ekleme bir using yönergesi System.IO ad alanı.

  • Projenize bu kodu kopyalayın.

  • Derlemek ve program çalıştırmak için F5 tuşuna basın.

  • Konsol penceresine çıkmak için herhangi bir tuşa basın.

Ayrıca bkz.

Kavramlar

LINQ ve Dizeler

LINQ ve Dosya Dizinleri