Zum Fußzeileninhalt springen
IRONXL VERWENDEN

Wie man eine Excel-Datei mit StreamReader in C# liest

Viele C#-Entwickler stehen vor der Herausforderung, Excel-Dateien zu lesen: Ihr vertrauter StreamReader, der perfekt für Textdateien funktioniert, versagt rätselhafterweise bei Excel-Dokumenten. Wenn Sie versucht haben, eine Excel-Datei in C# mit StreamReader zu lesen, und dabei auf unleserliche Zeichen oder Ausnahmen gestoßen sind, sind Sie nicht allein. Dieses Tutorial erklärt, warum StreamReader Excel-Dateien nicht direkt verarbeiten kann und zeigt die richtige Lösung mithilfe von IronXL ohne Excel Interop.

Die Verwirrung entsteht oft, weil CSV-Dateien, die Excel öffnen kann, mit StreamReader problemlos funktionieren. Echte Excel-Dateien (XLSX, XLS) erfordern jedoch einen grundlegend anderen Ansatz. Dieses Verständnis wird Ihnen Stunden der Fehlersuche ersparen und Sie zum richtigen Werkzeug für die Aufgabe führen.

So exportieren Sie ein DataGridView in eine Excel-Datei in VB.NET: Abbildung 1 - IronXL

Warum kann StreamReader keine Excel-Dateien lesen?

StreamReader ist für einfache Textdateien ausgelegt und liest Zeichendaten zeilenweise mit einer angegebenen Kodierung. Excel-Dateien, trotz ihres tabellarischen Erscheinungsbildes, sind eigentlich komplexe binäre oder ZIP-komprimierte XML-Strukturen, die StreamReader nicht interpretieren kann.

static void Main(string[] args)
{
 // This code will NOT work - demonstrates the problem
 using (StreamReader reader = new StreamReader("ProductData.xlsx"))
 {
    string content = reader.ReadLine(); // read data
    Console.WriteLine(content); // Outputs garbled binary data
 }
}
static void Main(string[] args)
{
 // This code will NOT work - demonstrates the problem
 using (StreamReader reader = new StreamReader("ProductData.xlsx"))
 {
    string content = reader.ReadLine(); // read data
    Console.WriteLine(content); // Outputs garbled binary data
 }
}
IRON VB CONVERTER ERROR developers@ironsoftware.com
$vbLabelText   $csharpLabel

Wenn Sie dieses Class Program Codebeispiel ausführen, sehen Sie statt Ihrer Tabellendaten Binärdaten unbekannten Ursprungs, wie z.B. "PK♥♦" oder ähnliche Systemzeichen. Dies geschieht, weil XLSX-Dateien ZIP-Archive sind, die mehrere XML-Dateien enthalten, während XLS-Dateien ein proprietäres binäres Format verwenden. StreamReader erwartet einfachen Text und versucht, diese komplexen Strukturen als Zeichen zu interpretieren, was zu sinnlosen Ausgaben führt.

Beispieldateieingabe

So exportieren Sie ein DataGridView in eine Excel-Datei in VB.NET: Abbildung 2 - Excel-Eingabe

Ausgabe

So exportieren Sie ein DataGridView in eine Excel-Datei in VB.NET: Abbildung 3 - Konsolenausgabe

Moderne Excel-Dateien (XLSX) enthalten mehrere Komponenten: Arbeitsblätter, Stile, gemeinsame Zeichenfolgen und Beziehungen, die alle zusammen verpackt sind. Diese Komplexität erfordert spezialisierte Bibliotheken, die die Excel-Dateistruktur verstehen, was uns zu IronXL führt.

Wie liest man Excel-Dateien mit IronXL?

IronXL bietet eine unkomplizierte Lösung zum Lesen von Excel-Dateien in C#. Im Gegensatz zu StreamReader versteht IronXL die interne Struktur von Excel und bietet intuitive Methoden, um auf Ihre Daten zuzugreifen. Die Bibliothek unterstützt Windows, Linux, macOS und Docker-Container, was sie ideal für moderne plattformübergreifende Anwendungen macht.

So lesen Sie eine Excel-Datei mit StreamReader in C#: Abbildung 4 - Plattformübergreifend

Zuerst installieren Sie IronXL über den NuGet-Paketmanager:

Install-Package IronXL.Excel

So lesen Sie eine Excel-Datei mit StreamReader in C#: Abbildung 5 - Installation

So lesen Sie eine Excel-Datei ordnungsgemäß:

using IronXL;
// Load the Excel file
WorkBook workbook = WorkBook.Load("sample.xlsx");
WorkSheet worksheet = workbook.DefaultWorkSheet;
// Read specific cell values
string cellValue = worksheet["A1"].StringValue;
Console.WriteLine($"Cell A1 contains: {cellValue}");
// Read a range of cells
foreach (var cell in worksheet["A1:C5"])
{
    Console.WriteLine($"{cell.AddressString}: {cell.Text}");
}
using IronXL;
// Load the Excel file
WorkBook workbook = WorkBook.Load("sample.xlsx");
WorkSheet worksheet = workbook.DefaultWorkSheet;
// Read specific cell values
string cellValue = worksheet["A1"].StringValue;
Console.WriteLine($"Cell A1 contains: {cellValue}");
// Read a range of cells
foreach (var cell in worksheet["A1:C5"])
{
    Console.WriteLine($"{cell.AddressString}: {cell.Text}");
}
IRON VB CONVERTER ERROR developers@ironsoftware.com
$vbLabelText   $csharpLabel

Dieser Code lädt Ihre Excel-Datei erfolgreich und bietet sauberen Zugriff auf Zellwerte. Die Methode WorkBook.Load erkennt automatisch das Dateiformat (XLSX, XLS, XLSM, CSV) und verarbeitet die gesamte komplexe Analyse intern. Sie können auf Zellen mit der bekannten Excel-Notation wie "A1" oder Bereichen wie "A1:C5" zugreifen, was den Code für jeden, der mit Excel vertraut ist, intuitiv macht.

Wie liest man Excel aus Memory Streams?

In realen Anwendungen müssen Excel-Dateien oft aus Streams und nicht von Datenträgern verarbeitet werden. Häufige Szenarien umfassen die Handhabung von Web-Uploads, das Abrufen von Dateien aus Datenbanken oder die Verarbeitung von Daten aus Cloud-Speichern. IronXL behandelt diese Situationen elegant:

using IronXL;
using System.IO;
// Read Excel from a memory stream
byte[] fileBytes = File.ReadAllBytes("ProductData.xlsx");
using (MemoryStream stream = new MemoryStream(fileBytes))
{
    WorkBook workbook = WorkBook.FromStream(stream);
    WorkSheet worksheet = workbook.DefaultWorkSheet;
    // Process the data
    int rowCount = worksheet.RowCount;
    Console.WriteLine($"The worksheet has {rowCount} rows");
    // Read all data into a new DataTable, return dt
    var dataTable = worksheet.ToDataTable(false);
    // Return DataTable row count 
    Console.WriteLine($"Loaded {dataTable.Rows.Count} data rows");
}
using IronXL;
using System.IO;
// Read Excel from a memory stream
byte[] fileBytes = File.ReadAllBytes("ProductData.xlsx");
using (MemoryStream stream = new MemoryStream(fileBytes))
{
    WorkBook workbook = WorkBook.FromStream(stream);
    WorkSheet worksheet = workbook.DefaultWorkSheet;
    // Process the data
    int rowCount = worksheet.RowCount;
    Console.WriteLine($"The worksheet has {rowCount} rows");
    // Read all data into a new DataTable, return dt
    var dataTable = worksheet.ToDataTable(false);
    // Return DataTable row count 
    Console.WriteLine($"Loaded {dataTable.Rows.Count} data rows");
}
IRON VB CONVERTER ERROR developers@ironsoftware.com
$vbLabelText   $csharpLabel

Die WorkBook.FromStream-Methode akzeptiert jeden Stream-Typ, sei es ein MemoryStream, FileStream oder ein Netzwerkstream. Diese Flexibilität ermöglicht es Ihnen, Excel-Dateien aus verschiedenen Quellen zu verarbeiten, ohne sie zuerst auf der Festplatte speichern zu müssen. Das Beispiel zeigt auch, wie Arbeitsblattdaten in eine DataTable konvertiert werden, die nahtlos mit Datenbanken und Datenbindungsszenarien integriert wird.

Ausgabe

So lesen Sie eine Excel-Datei mit StreamReader in C#: Abbildung 6 - Lesen von Excel aus dem MemoryStream-Ausgang

Wann sollte man das Objekt sender verwenden, um Daten zu lesen?

In Fällen, in denen dieser Code im ereignisgesteuerten Programmieren verwendet wird (z.B. beim Handhaben eines Datei-Upload-Buttons in Windows Forms oder ASP.NET), enthält die Methodensignatur oft Parameter wie das Objekt sender und EventArgs e. Dieser Kontext stellt sicher, dass die Excel-Verarbeitung logisch korrekt in Benutzeroberflächen- oder Dienstereignisse eingebunden wird.

So lesen Sie eine Excel-Datei mit StreamReader in C#: Abbildung 7 - Funktionen

Wie konvertiert man zwischen Excel und CSV?

Obwohl StreamReader CSV-Dateien verarbeiten kann, müssen Sie oft zwischen Excel- und CSV-Formaten konvertieren. IronXL macht diese Konvertierung unkompliziert:

using IronXL;
// Load an Excel file and save as CSV
WorkBook workbook = WorkBook.Load("data.xlsx");
workbook.SaveAsCsv("output.csv");
// Load a CSV file and save as Excel
WorkBook csvWorkbook = WorkBook.LoadCSV("input.csv");
csvWorkbook.SaveAs("output.xlsx");
// Export specific worksheet to CSV
WorkSheet worksheet = workbook.WorkSheets[0];
worksheet.SaveAsCsv("worksheet1.csv");
using IronXL;
// Load an Excel file and save as CSV
WorkBook workbook = WorkBook.Load("data.xlsx");
workbook.SaveAsCsv("output.csv");
// Load a CSV file and save as Excel
WorkBook csvWorkbook = WorkBook.LoadCSV("input.csv");
csvWorkbook.SaveAs("output.xlsx");
// Export specific worksheet to CSV
WorkSheet worksheet = workbook.WorkSheets[0];
worksheet.SaveAsCsv("worksheet1.csv");
IRON VB CONVERTER ERROR developers@ironsoftware.com
$vbLabelText   $csharpLabel

Diese Konvertierungen erhalten Ihre Daten bei gleichzeitiger Änderung des Dateiformats. Beim Konvertieren von Excel in CSV flacht IronXL standardmäßig das erste Arbeitsblatt ab, Sie können jedoch festlegen, welches Arbeitsblatt exportiert werden soll. Das Konvertieren von CSV nach Excel erzeugt ein korrekt formatiertes Tabellenblatt, das Datentypen beibehält und zukünftige Formatierungen und Formeln ermöglicht.

Abschluss

Die Unfähigkeit von StreamReader, Excel-Dateien zu verarbeiten, rührt von dem grundlegenden Unterschied zwischen einfachem Text und der komplexen Dateistruktur von Excel her. Während StreamReader perfekt für CSV- und andere Textformate funktioniert, erfordern echte Excel-Dateien eine spezialisierte Bibliothek wie IronXL, die die binären und XML-Strukturen darin versteht.

IronXL bietet eine elegante Lösung mit seiner intuitiven API, umfassender Formatunterstützung und nahtlosen Stream-Verarbeitungsfähigkeiten. Egal ob Sie Web-Anwendungen, Desktop-Software oder Cloud-Dienste entwickeln, IronXL verarbeitet Excel-Dateien zuverlässig auf allen Plattformen.

So lesen Sie eine Excel-Datei mit StreamReader in C#: Abbildung 8 - Lizenzierung

Bereit, um mit Excel-Dateien richtig zu arbeiten? Laden Sie das kostenfreie Testversion von IronXL herunter, das am besten zu den Bedürfnissen Ihres Projekts passt.

Häufig gestellte Fragen

Warum kann StreamReader in C# keine Excel-Dateien lesen?

StreamReader ist darauf ausgelegt, Textdateien zu lesen und kann mit dem binären Format von Excel-Dateien nicht umgehen, was zu wirren Zeichen oder Ausnahmen führt.

Was ist IronXL?

IronXL ist eine C#-Bibliothek, die es Entwicklern ermöglicht, Excel-Dateien zu lesen, zu schreiben und zu manipulieren, ohne Excel Interop.

Wie verbessert IronXL das Lesen von Excel-Dateien in C#?

IronXL vereinfacht den Prozess des Lesens von Excel-Dateien, indem es Methoden bereitstellt, um auf Excel-Daten zuzugreifen, ohne komplexen Interop-Code oder die Auseinandersetzung mit Dateiformatkomplexitäten zu benötigen.

Kann ich IronXL verwenden, um Excel-Dateien ohne installiertes Excel zu lesen?

Ja, IronXL erfordert nicht, dass Microsoft Excel auf Ihrem System installiert ist, was es zu einer eigenständigen Lösung für den Umgang mit Excel-Dateien in C# macht.

Was sind die Vorteile der Verwendung von IronXL gegenüber Excel Interop?

IronXL ist schneller, beseitigt die Notwendigkeit, Excel zu installieren, und reduziert das Risiko von Versionskompatibilitätsproblemen, die bei Excel Interop häufig auftreten.

Ist IronXL für große Excel-Dateien geeignet?

Ja, IronXL ist für Leistung optimiert und kann große Excel-Dateien effizient verarbeiten, was es für Anwendungen geeignet macht, die mit umfangreichen Daten arbeiten.

Unterstützt IronXL .xls- und .xlsx-Formate?

IronXL unterstützt .xls- und .xlsx-Formate, wodurch Entwickler flexibel arbeiten können.

Wie starte ich IronXL in meinem C#-Projekt?

Sie können mit der Nutzung von IronXL beginnen, indem Sie es über den NuGet-Paket-Manager in Visual Studio installieren und in Ihr C#-Projekt integrieren, um Excel-Dateien zu lesen und zu manipulieren.

Was sind die üblichen Anwendungsfälle für IronXL?

Typische Anwendungsfälle für IronXL sind Datenextraktion, Berichtserstellung und Automatisierung von Excel-Aufgaben in C#.

Kann IronXL in Webanwendungen verwendet werden?

Ja, IronXL kann sowohl in Desktop- als auch in Webanwendungen verwendet werden und bietet Flexibilität bei der Implementierung von Excel-Verarbeitungsfähigkeiten in Ihren Projekten.

Jordi Bardia
Software Ingenieur
Jordi ist am besten in Python, C# und C++ versiert. Wenn er nicht bei Iron Software seine Fähigkeiten einsetzt, programmiert er Spiele. Mit Verantwortung für Produkttests, Produktentwicklung und -forschung trägt Jordi mit immensem Wert zur kontinuierlichen Produktverbesserung bei. Die abwechslungsreiche Erfahrung hält ihn gefordert und engagiert, ...
Weiterlesen