The Artima Developer Community
Sponsored Link

.NET Buzz Forum
LINQ: Daten aus Textdateien mittels LINQ in einer DataGridView anzeigen

0 replies on 1 page.

Welcome Guest
  Sign In

Go back to the topic listing  Back to Topic List Click to reply to this topic  Reply to this Topic Click to search messages in this forum  Search Forum Click for a threaded view of the topic  Threaded View   
Previous Topic   Next Topic
Flat View: This topic has 0 replies on 1 page
-

Posts: 1524
Nickname: nitronic
Registered: Jul, 2006

Norbert Eder works as a software architect.
LINQ: Daten aus Textdateien mittels LINQ in einer DataGridView anzeigen Posted: Oct 29, 2007 4:37 AM
Reply to this message Reply

This post originated from an RSS feed registered with .NET Buzz by -.
Original Post: LINQ: Daten aus Textdateien mittels LINQ in einer DataGridView anzeigen
Feed Title: Norbert Eder - Living .NET
Feed URL: http://feeds.feedburner.com/NorbertEder-Livingnet
Feed Description: Copyright (c)2005, 2006 by Norbert Eder
Latest .NET Buzz Posts
Latest .NET Buzz Posts by -
Latest Posts From Norbert Eder - Living .NET

Advertisement
Mit LINQ ist nicht immer nur LINQ to SQL gemeint. Es lassen sich auch ganz andere Dinge damit erledigen. In diesem Beitrag wird erklärt, wie wie Hilfe von LINQ Daten aus einer Textdatei mit komma-separierten Trennzeichen (CVS beispielsweise) in einem DataGridView zur Anzeige gebracht werden können. Um dies zu erreichen, muss unter anderem das Schlüsselwort yield verwendet werden. Wir benötigen nämlich die Möglichkeit, durch die Daten der angegebenen Textdatei zu iterieren - zeilenweise. Hierfür wird folgende Methode verwendet:
private IEnumerable<string[]> LoadFile(string delim, StreamReader sr)
{
    while (sr.Peek() != -1)
        yield return sr.ReadLine().Split(delim.ToCharArray());
}

Dem zugrunde liegt die Datei Adressen.txt, die folgende Daten zur Verfügung stellt:
Norbert;Eder;Irgendeine Strasse 1;10000;Irgendein Ort
Klaus;Mustermann;Mustermann Strasse 1;10000;Irgendein Ort

Für die Erstellung der notwendigen Objekte und der damit möglichen Anzeige der Daten wird nun folgender Codeblock verwendet:
if (File.Exists("Adressen.txt"))
{
    StreamReader sr = new StreamReader("Adressen.txt");

    var addressList = from field in LoadFile(";", sr)
                      select new
                          {
                              Firstname = field[0],
                              Lastname = field[1],
                              Street = field[2],
                              PostalCode = field[3],
                              City = field[4],
                          };

    List<object> tempList = new List<object>();
    foreach (var address in addressList)
        tempList.Add(address);

    this.DataGridView.DataSource = tempList;                
}

Mittels LINQ wird quasi ein Select auf die von LoadFile zurückgegebenen Enumerations-Werte ausgeführt und in eine Liste geschrieben. Anschließend werden die Informationen zur Anzeige gebracht.

Schlussendlich sieht das Ergebnis so aus:


Read: LINQ: Daten aus Textdateien mittels LINQ in einer DataGridView anzeigen

Topic: New Software Patterns Articles Previous Topic   Next Topic Topic: IHttpHandlerFactory and URL Mapping

Sponsored Links



Google
  Web Artima.com   

Copyright © 1996-2019 Artima, Inc. All Rights Reserved. - Privacy Policy - Terms of Use