Test in einer Live-Umgebung
Test in der Produktion ohne Wasserzeichen.
Funktioniert überall, wo Sie es brauchen.
In der heutigen datengesteuerten Welt ist Microsoft Excel ein unverzichtbares Werkzeug für Unternehmen und Fachleute gleichermaßen. Ob es um die Berechnung von Zahlen, die Erstellung von Berichten oder die Visualisierung von Daten geht, die Vielseitigkeit von Excel ist unübertroffen. Wenn es jedoch darum geht, Excel-Dateien in C# programmatisch zu bearbeiten, stehen Entwickler oft vor Herausforderungen. Dies ist der Ort, an dem IronXL bibliothek ins Spiel, die eine nahtlose Lösung für die Excel-Automatisierung innerhalb der C#-Umgebung bietet.
IronXL bibliothek von Iron Software bietet intuitive APIs für den nahtlosen Umgang mit Excel-Dokumenten sowohl in C# .NET- als auch in VB.NET-Umgebungen. Mit IronXL ist es nicht erforderlich, Microsoft Office oder Excel Interop Komponenten zu installieren. Es ermöglicht Entwicklern das mühelose Lesen, Bearbeiten und Erstellen von Excel-Tabellendateien und bietet volle Unterstützung für verschiedene .NET-Frameworks, einschließlich .NET 8, 7, 6, Core Frameworks und Azure-Umgebungen.
In diesem Artikel erfahren Sie, wie Sie die Spaltenbreite und -höhe in Excel mit C# und IronXL automatisch anpassen können.
Installieren Sie IronXL bibliothek für das Projekt.
Automatische Anpassung der Spaltenbreite mit der IronXL-Bibliothek.
Automatische Anpassung der Reihenhöhe mit der Bibliothek IronXL.
IronXL bibliothek ist eine vielseitige .NET-Bibliothek, die die Bearbeitung von Excel-Tabellen für C#-Entwickler vereinfacht. IronXL bietet eine schnelle und intuitive API, mit der Benutzer mühelos auf Excel-Dateien zugreifen, diese ändern und generieren können, ohne auf Office Interop angewiesen zu sein. Seine Kompatibilität erstreckt sich auf verschiedene .NET-Frameworks, einschließlich .NET Core und Azure, ohne dass spezielle Abhängigkeiten oder die Installation von Microsoft Office erforderlich sind. Durch die Unterstützung mehrerer .NET-Sprachen wie C#, VB.NET und F# eignet sich IronXL für eine breite Palette von Entwicklungsszenarien, einschließlich Konsolen-, Web- und Desktop-Anwendungen. Darüber hinaus ist IronXL plattformübergreifend kompatibel, einschließlich Windows, Linux, macOS, Docker, Azure und AWS, was es zu einem unverzichtbaren Werkzeug für Entwickler macht, die eine effiziente Excel-Integration in unterschiedlichen Umgebungen anstreben.
Einfache Integration: IronXL lässt sich nahtlos in C#-Anwendungen integrieren und bietet eine einfache und intuitive API für die Excel-Automatisierung. Entwickler können mit einer minimalen Lernkurve schnell loslegen.
Lesen und Schreiben von Excel-Dateien: Mit IronXL können Sie mühelos Daten aus bestehenden Excel-Dateien lesen und Daten in neue oder bestehende Tabellenblätter schreiben. Diese Fähigkeit ist für Aufgaben wie den Datenimport/-export und die Berichterstellung unerlässlich.
Formatieren und Gestalten: IronXL ermöglicht es Ihnen, Excel-Zellen zu formatieren und zu gestalten, einschließlich Schriftarten, Farben, Rahmen und mehr. Dadurch wird sichergestellt, dass die von Ihnen erstellten Excel-Dateien ein professionelles und geschliffenes Aussehen erhalten.
Formelunterstützung: Sie müssen komplexe Berechnungen durchführen oder Formeln auf Excel-Daten anwenden? IronXL bietet Ihnen Unterstützung für Excel-Formeln, mit denen Sie Berechnungen und Datenmanipulationen automatisieren können.
Um zu beginnen, erstellen wir ein Visual Studio-Projekt wie unten gezeigt. Wählen Sie die Vorlage für die Konsolenanwendung aus der Liste aus
Geben Sie einen Projektnamen und einen Standort an
Wählen Sie die gewünschte .NET-Version aus der Dropdown-Liste und klicken Sie auf "Erstellen"
Installieren Sie IronXL bibliothek von Visual Studio NuGet Package Manager
Das Paket kann auch über die NuGet-Befehlszeile installiert werden
dotnet add package IronXL.Excel --version 2024.3.20
// or
Install-Package IronXL.Excel
dotnet add package IronXL.Excel --version 2024.3.20
// or
Install-Package IronXL.Excel
'INSTANT VB TODO TASK: The following line uses invalid syntax:
'dotnet add package IronXL.Excel --version 2024.3.20 Install-Package IronXL.Excel
Damit sind wir bereit, mit der Codierung zu beginnen.
Die Methode AutoSizeColumn von IronXL bibliothek passt die Breite einer Spalte an ihren Inhalt an. Diese Methode berechnet die Textbreite auf der Grundlage der in der Zelle verwendeten Schriftart. Wenn die genaue Schriftart nicht auf dem System verfügbar ist, wird versucht, sie mit einer Standardschriftart zu messen. Wenn keine Standardschriftart gefunden wird, wird versucht, eine beliebige verfügbare Schriftart zu verwenden. Wenn jedoch keine Schriftarten gefunden werden, wird eine Ausnahme ausgelöst. Sie verwendet einen nullbasierten Spaltenindex als Parameter. Er muss innerhalb der Grenzen von 0 und (SpalteZahl - 1). eine ArgumentException wird ausgelöst, wenn der angegebene columnIndex außerhalb des gültigen Bereichs liegt. die SixLabors.Fonts.FontException wird ausgelöst, wenn keine Schriftarten auf dem Rechner installiert sind.
Sehen wir uns nun an, wie wir damit die Größe einer Excel-Datei ändern können. Sie können eine Excel-Beispieldatei herunterladen unter hier.
Hier können Sie sehen, dass die Spaltenbreiten nicht richtig definiert sind und daher sehr schwer zu lesen sind. Jetzt wollen wir
sehen, wie wir die IronXL-Bibliothek zur automatischen Anpassung der Spaltenbreiten in einem Excel-Blatt verwenden können.
using IronXL;
// Load example spreadsheet
WorkBook workBook = WorkBook.Load("FinancialSample.xlsx");
WorkSheet workSheet = workBook.DefaultWorkSheet;
var colCount = workSheet.Columns.Count();
for (int i = 0; i < colCount; i++)
{
// auto fit column width for index i
workSheet.AutoSizeColumn(i);
}
workBook.SaveAs("autoResize.xlsx"); // result file
using IronXL;
// Load example spreadsheet
WorkBook workBook = WorkBook.Load("FinancialSample.xlsx");
WorkSheet workSheet = workBook.DefaultWorkSheet;
var colCount = workSheet.Columns.Count();
for (int i = 0; i < colCount; i++)
{
// auto fit column width for index i
workSheet.AutoSizeColumn(i);
}
workBook.SaveAs("autoResize.xlsx"); // result file
Imports IronXL
' Load example spreadsheet
Private workBook As WorkBook = WorkBook.Load("FinancialSample.xlsx")
Private workSheet As WorkSheet = workBook.DefaultWorkSheet
Private colCount = workSheet.Columns.Count()
For i As Integer = 0 To colCount - 1
' auto fit column width for index i
workSheet.AutoSizeColumn(i)
Next i
workBook.SaveAs("autoResize.xlsx") ' result file
Zunächst laden wir die Datei FinancialSample.xlsx mit WorkBook.Load() Methode.
Dann erhalten wir den Zellbereich, für den die Spaltenbreiten angepasst werden müssen, in diesem Fall die Spaltenanzahl.
Dann werden alle Indizes durchlaufen, um die Spaltenbreiten automatisch zu skalieren
Unten sehen Sie, dass alle Spalten automatisch skaliert und sichtbar sind.
Die Methode AutoSizeRow passt die Höhe einer Zeile an ihren Inhalt an. Es ist wichtig zu beachten, dass diese Methode die Texthöhe auf der Grundlage der in der Zelle verwendeten Schriftart berechnet. Wenn die genaue Schriftart nicht auf dem System verfügbar ist, wird versucht, sie mit einer Standardschriftart zu messen. Wenn keine Standardschriftart gefunden wird, wird versucht, eine beliebige verfügbare Schriftart zu verwenden. Wenn jedoch keine Schriftarten gefunden werden, wird eine Ausnahme ausgelöst. Sie verwendet einen nullbasierten Zeilenindex als Parameter. Er muss innerhalb der Grenzen von 0 und (RowCount - 1). eine ArgumentException wird ausgelöst, wenn der angegebene rowIndex außerhalb des gültigen Bereichs liegt. SixLabors.Fonts.FontException** wird ausgelöst, wenn keine Schriftarten auf dem Rechner installiert sind
Im folgenden Beispiel sehen Sie, dass einige der Zeilen nicht die richtige Größe haben, um die Daten zu fixieren. Schauen wir uns nun den C#-Code für die automatische Anpassung der Excel-Zeilenhöhen an.
using IronXL;
// Load example spreadsheet
WorkBook workBook = WorkBook.Load("FinancialSample.xlsx");
WorkSheet workSheet = workBook.DefaultWorkSheet;
var rowCount = workSheet.RowCount;
for (int i = 0; i < rowCount; i++)
{
workSheet.AutoSizeRow(i);
}
workBook.SaveAs("autoResizeRows.xlsx"); // result file
using IronXL;
// Load example spreadsheet
WorkBook workBook = WorkBook.Load("FinancialSample.xlsx");
WorkSheet workSheet = workBook.DefaultWorkSheet;
var rowCount = workSheet.RowCount;
for (int i = 0; i < rowCount; i++)
{
workSheet.AutoSizeRow(i);
}
workBook.SaveAs("autoResizeRows.xlsx"); // result file
Imports IronXL
' Load example spreadsheet
Private workBook As WorkBook = WorkBook.Load("FinancialSample.xlsx")
Private workSheet As WorkSheet = workBook.DefaultWorkSheet
Private rowCount = workSheet.RowCount
For i As Integer = 0 To rowCount - 1
workSheet.AutoSizeRow(i)
Next i
workBook.SaveAs("autoResizeRows.xlsx") ' result file
Zunächst laden wir die Datei FinancialSample.xlsx mit WorkBook.Load() Methode.
Dann erhalten wir den Zellbereich, für den die Zeilenhöhen angepasst werden müssen, in diesem Fall die Zeilenzahl.
Dann werden alle Indizes durchlaufen, um die Zeilenhöhen automatisch zu skalieren
Neben der automatischen Größenanpassung von Zeilen und Spalten bietet IronXL auch die Möglichkeit, die Breite und Höhe manuell auf einen bestimmten Wert für die Zeilenhöhe und eine bestimmte Spaltenbreite einzustellen
using IronXL;
// Load example spreadsheet
WorkBook workBook = WorkBook.Load("FinancialSample.xlsx");
WorkSheet workSheet = workBook.DefaultWorkSheet;
RangeRow row = workSheet.GetRow(0);
row.Height = 500; // Set height
RangeColumn col = workSheet.GetColumn(0);
col.Width = 5000; // Set width
workBook.SaveAs("specificValue.xlsx");
using IronXL;
// Load example spreadsheet
WorkBook workBook = WorkBook.Load("FinancialSample.xlsx");
WorkSheet workSheet = workBook.DefaultWorkSheet;
RangeRow row = workSheet.GetRow(0);
row.Height = 500; // Set height
RangeColumn col = workSheet.GetColumn(0);
col.Width = 5000; // Set width
workBook.SaveAs("specificValue.xlsx");
Imports IronXL
' Load example spreadsheet
Private workBook As WorkBook = WorkBook.Load("FinancialSample.xlsx")
Private workSheet As WorkSheet = workBook.DefaultWorkSheet
Private row As RangeRow = workSheet.GetRow(0)
row.Height = 500 ' Set height
Dim col As RangeColumn = workSheet.GetColumn(0)
col.Width = 5000 ' Set width
workBook.SaveAs("specificValue.xlsx")
Zunächst laden wir die Datei FinancialSample.xlsx mit WorkBook.Load() Funktion.
Dann erhalten wir den Zellbereich, für den die Zeilenhöhen angepasst werden müssen, und auch den Zellbereich, für den die Spaltenbreiten angepasst werden müssen
Dann setzen wir die Werte für Höhe und Breite
Die erhaltene Lizenz muss in der Datei appSettings.json eingetragen werden
{
"IronXL.License.LicenseKey":"myTrialKey"
}
{
"IronXL.License.LicenseKey":"myTrialKey"
}
If True Then
"IronXL.License.LicenseKey":"myTrialKey"
End If
Mit Funktionen wie AutoSizeColumn und AutoSizeRow von IronXLkönnen Entwickler mühelos sicherstellen, dass sich Excel-Tabellen dynamisch an den Inhalt anpassen, den sie enthalten, egal ob es sich um importierte Daten, dynamische Berichte, benutzergenerierte Inhalte oder Datenanalyseergebnisse handelt.
IronXLdie Kompatibilität von IronXL mit verschiedenen .NET-Frameworks, einschließlich .NET Core und Azure, stellt sicher, dass Entwickler die Excel-Automatisierung in ein breites Spektrum von Anwendungen integrieren können, ohne von Microsoft Office oder Excel Interop abhängig zu sein. Darüber hinaus ist IronXL durch die Unterstützung mehrerer .NET-Sprachen und -Plattformen eine vielseitige Wahl für Entwickler, die Excel-Bearbeitungsaufgaben in unterschiedlichen Umgebungen rationalisieren möchten.
Im Grunde genommen, IronXL gibt Entwicklern die Möglichkeit, die Produktivität, Genauigkeit und Flexibilität in Excel-Automatisierungsprojekten zu verbessern, und bietet eine umfassende Reihe von Funktionen, die den Anforderungen der modernen C#-Entwicklung entsprechen. Ob es um die Erstellung von Berichten, die Analyse von Daten oder die Präsentation von Informationen geht, IronXL bietet die notwendigen Werkzeuge, um in der Excel-Automatisierung innerhalb des C#-Ökosystems zu glänzen.
9 .NET API-Produkte für Ihre Bürodokumente