Zum Fußzeileninhalt springen
IRONXL VERWENDEN

Alternative zum Lesen von Excel-Dateien mit StreamReader in C# - IronXL

Viele C#-Entwickler stoßen auf ein häufiges Problem, wenn sie versuchen, Excel-Dateien zu lesen: Ihr vertrauter StreamReader, der für Textdateien perfekt funktioniert, versagt auf mysteriöse Weise bei Excel-Dokumenten. Wenn Sie schon einmal versucht haben, eine Excel-Datei mit StreamReader in C# zu lesen, und nur verstümmelte Zeichen oder Ausnahmen gesehen haben, sind Sie nicht allein. Dieses Tutorial erklärt, warum StreamReader nicht direkt mit Excel-Dateien umgehen kann und demonstriert die richtige Lösung mit IronXL ohne Excel Interop.

Die Verwirrung entsteht oft, weil CSV-Dateien, die Excel öffnen kann, mit StreamReader gut 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.

Alternative zum Lesen von Excel-Dateien mit StreamReader in C# - IronXL: Image 1 - IronXL

Warum kann StreamReader keine Excel-Dateien lesen?

StreamReader ist für reine Textdateien konzipiert und liest Zeichendaten Zeile für Zeile in einer bestimmten Kodierung. Excel-Dateien sehen zwar wie Tabellenkalkulationen aus, sind aber 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 einer sinnlosen Ausgabe führt.

Beispiel-Input

Alternative zum Lesen von Excel-Dateien mit StreamReader in C# - IronXL: Image 2 - Excel Input

Ausgabe

Alternative zum Lesen von Excel-Dateien mit StreamReader in C# - IronXL: Bild 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 für das Lesen von Excel-Dateien in C#. Anders als StreamReader versteht IronXL die interne Struktur von Excel und bietet intuitive Methoden für den Zugriff auf Ihre Daten. Die Bibliothek unterstützt Windows, Linux, macOS und Docker-Container, was sie ideal für moderne plattformübergreifende Anwendungen macht.

Alternative zum Lesen von Excel-Dateien mit StreamReader in C# - IronXL: Image 4 - Cross Platform

Zuerst installieren Sie IronXL über den NuGet-Paketmanager:

Install-Package IronXL.Excel
Install-Package IronXL.Excel
SHELL

Alternative zum Lesen von Excel-Dateien mit StreamReader in C# - IronXL: Bild 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 führt alle komplexen Parsingvorgänge intern durch. Sie können auf Zellen mit vertrauter Excel-Notation wie "A1" oder Bereichen wie "A1:C5" zugreifen, was den Code intuitiv für jeden macht, der mit Excel vertraut ist.

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 Methode WorkBook.FromStream akzeptiert jeden Stream-Typ, egal ob es sich um einen MemoryStream, FileStream oder einen Netzwerkstream handelt. 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

Alternative zum Lesen von Excel-Dateien mit StreamReader in C# - IronXL: Bild 6 - Lesen von Excel aus MemoryStream Output

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

In Fällen, in denen dieser Code im Rahmen der ereignisgesteuerten Programmierung verwendet wird (z. B. bei der Handhabung einer Schaltfläche zum Hochladen einer Datei in Windows Forms oder ASP.NET), enthält die Signatur der einen Methode häufig Parameter wie object sender und EventArgs e. Alt-Text zum Bild hinzufügen.

Alternative zum Lesen von Excel-Dateien mit StreamReader in C# - IronXL: Image 7 - Features

Wie konvertiert man zwischen Excel und CSV?

Während 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 spezielle 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.

Alternative zum Lesen von Excel-Dateien mit StreamReader in C# - IronXL: Image 8 - Lizenzierung

Bereit, um mit Excel-Dateien richtig zu arbeiten? Laden Sie die kostenlose Testversion von IronXL herunter und erleben Sie die problemlose Excel-Verarbeitung in Ihren C#-Anwendungen. Für den produktiven Einsatz sollten Sie IronXL-Lizenzierungsoptionen in Betracht ziehen, die den Anforderungen Ihres Projekts am besten entsprechen.

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