Wie man PDF-Dateien in C# speichert (Einsteiger-Tutorial)
Dieser Artikel wird untersuchen, wie man IronPDF verwendet, um PDF-Dateien aus einer Windows Forms-Anwendung oder einer beliebigen .NET-Anwendung zu speichern.
Die IronPDF-Bibliothek ist eine .NET-Bibliothek, die einfach zu verwendende Klassen und Methoden zum Erzeugen und Bearbeiten von PDF-Dateien in C#-Anwendungen bereitstellt. Sie ermöglicht es Entwicklern, PDF-Dateien mit nur wenigen Codezeilen zu erstellen, zu ändern und zu speichern, was sie zu einer ausgezeichneten Wahl für Windows Forms-Anwendungen macht.
Schritt 1: Erstellen Sie eine neue Windows Forms-Anwendung
Erstellen Sie zuerst ein neues Visual Studio-Projekt. Hier sind die Schritte, um eine neue C# Windows Forms-Anwendung in Visual Studio 2022 zu erstellen
-
Öffnen Sie Visual Studio 2022 wie unten gezeigt.
Visual Studio 2022 - Klicken Sie auf der Startseite auf "Create a new project" oder gehen Sie zu "File" > "New" > "Project".
-
Wählen Sie im Dialogfeld "Create a new project" "Windows Forms App" oder "Windows Forms App (.NET Framework)" unter "Create a new project", wie unten gezeigt.
Neue Forms-App -
Geben Sie einen Namen für Ihr Projekt ein und wählen Sie einen Speicherort.
Projektstandort - Wählen Sie .NET Framework. Wählen Sie .NET 7.0 aus dem Dropdown-Menü.
-
Klicken Sie auf die Create-Schaltfläche.
Zusatzinformationen -
Visual Studio erstellt für Sie ein neues C# Windows Forms-Anwendung Projekt, mit einem Standardformular namens "Form1", das dem Projekt hinzugefügt wird, wie unten gezeigt.
Form1-Projekt
Das war's! Jetzt beginnen wir mit dem Erstellen der Windows Forms-Anwendung mit dem Designer, indem wir Steuerelemente und Funktionsfähigkeiten zum Erstellen und Speichern einer PDF-Dokumentdatei hinzufügen.
Schritt 2: Entwerfen Sie das Formular
Sie können das Formular nach Ihren Vorlieben gestalten. In diesem Tutorial wird ein minimalistisches Design erstellt, indem zwei Beschriftungen, ein RichTextBox und zwei Schaltflächen hinzugefügt werden.
Schaltflächen zum Formular hinzufügen
Schritt 3: Installieren Sie IronPDF
Der nächste Schritt besteht darin, IronPDF in diesem Projekt zu installieren, um seine umfangreichen Funktionen zu nutzen.
IronPDF kann mit dem NuGet Package Manager in Visual Studio installiert werden. Sie können zur NuGet Package Manager-Konsole navigieren, indem Sie zu Tools > NuGet Package Manager > Package Manager Console gehen.
Geben Sie den Befehl ein und drücken Sie Enter:
Install-Package IronPdf
Dieser Befehl lädt das IronPDF-Paket in Ihr Projekt herunter und installiert es. Nach der Installation können wir IronPDF verwenden.
Code schreiben, um PDF-Dateien zu erstellen und zu speichern
Um mit dem Ablauf zu beginnen, schreiben Sie zwei Methoden: Save_Click und getFilePath in der Klasse Form1.cs. Diese Methoden werden gemeinsam verwendet, um den Inhalt einer Textbox als PDF-Datei zu speichern, indem die ChromePdfRenderer-Klasse-Bibliothek verwendet wird. Gehen wir jede Methode durch, um zu verstehen, wie sie funktioniert.
Save_Click Methode (PDF-Dokument erstellen)
Die folgende Methode ist ein Ereignishandler für ein Schaltflächenklick-Ereignis. Der Zweck dieser Methode besteht darin, den Inhalt einer Textbox als PDF-Datei zu speichern.
private void Save_Click(object sender, EventArgs e)
{
// Get the file path to save the PDF file.
string filename = getFilePath();
// If the file path is not empty or null, proceed with saving the PDF file.
if (!String.IsNullOrEmpty(filename))
{
// Create a new instance of the ChromePdfRenderer class.
var renderer = new ChromePdfRenderer();
// Render the file contents of the text box as a PDF document using the ChromePdfRenderer.
var pdfDocument = renderer.RenderHtmlAsPdf(pdfContent.Text);
// Save the PDF document to the specified file path using the SaveAs method.
pdfDocument.SaveAs(filename);
// Show a message box to indicate that the PDF file has been saved successfully.
MessageBox.Show("PDF has been saved Successfully!");
}
}
private void Save_Click(object sender, EventArgs e)
{
// Get the file path to save the PDF file.
string filename = getFilePath();
// If the file path is not empty or null, proceed with saving the PDF file.
if (!String.IsNullOrEmpty(filename))
{
// Create a new instance of the ChromePdfRenderer class.
var renderer = new ChromePdfRenderer();
// Render the file contents of the text box as a PDF document using the ChromePdfRenderer.
var pdfDocument = renderer.RenderHtmlAsPdf(pdfContent.Text);
// Save the PDF document to the specified file path using the SaveAs method.
pdfDocument.SaveAs(filename);
// Show a message box to indicate that the PDF file has been saved successfully.
MessageBox.Show("PDF has been saved Successfully!");
}
}
Private Sub Save_Click(ByVal sender As Object, ByVal e As EventArgs)
' Get the file path to save the PDF file.
Dim filename As String = getFilePath()
' If the file path is not empty or null, proceed with saving the PDF file.
If Not String.IsNullOrEmpty(filename) Then
' Create a new instance of the ChromePdfRenderer class.
Dim renderer = New ChromePdfRenderer()
' Render the file contents of the text box as a PDF document using the ChromePdfRenderer.
Dim pdfDocument = renderer.RenderHtmlAsPdf(pdfContent.Text)
' Save the PDF document to the specified file path using the SaveAs method.
pdfDocument.SaveAs(filename)
' Show a message box to indicate that the PDF file has been saved successfully.
MessageBox.Show("PDF has been saved Successfully!")
End If
End Sub
Hier ist eine Schritt-für-Schritt-Breakdown dessen, was diese Methode tut:
- Die Methode ruft die Methode
getFilePathauf, um den Dateipfad zu erhalten, unter dem die PDF-Datei gespeichert werden soll. - Wenn der Dateipfad nicht leer oder null ist, fährt die Methode mit dem Speichern der PDF-Datei fort.
- Die Methode erzeugt eine neue Instanz der Klasse
ChromePdfRenderer. Dies ist eine Bibliothek, die eine Möglichkeit bietet, HTML-Inhalte in PDF-Dokumente mit der Google Chrome-Browser-Engine zu konvertieren. - Anschließend verwendet die Methode die RenderHtmlAsPdf-Methode der Klasse
ChromePdfRenderer, um den HTML-Inhalt des TextfeldspdfContentin ein PDF-Dokument umzuwandeln. Dieses PDF-Dokument wird der PdfDocument-Variable zugewiesen. - Die Methode speichert das PDF-Dokument unter dem angegebenen Dateipfad mithilfe der SaveAs-Methode der Klasse
PdfDocument. - Schließlich zeigt die Methode ein Nachrichtenfeld an, um anzuzeigen, dass die PDF-Datei erfolgreich gespeichert wurde.
getFilePath Methode (PDF-Dateien speichern)
Diese Methode dient dazu, dem Benutzer SaveFileDialog anzuzeigen, damit er einen Dateipfad auswählen kann, in dem die PDF-Datei gespeichert werden soll.
public string getFilePath()
{
// Create a new instance of the SaveFileDialog class.
SaveFileDialog saveFileDialog1 = new SaveFileDialog();
// Set the initial directory where the SaveFileDialog will open.
saveFileDialog1.InitialDirectory = @"D:\";
// Set the title of the SaveFileDialog.
saveFileDialog1.Title = "Save the PDF Files";
// Set the SaveFileDialog to check if the specified path exists.
saveFileDialog1.CheckPathExists = true;
// Set the default extension for the file type.
saveFileDialog1.DefaultExt = ".pdf";
// Set the filter to display only PDF files or all files.
saveFileDialog1.Filter = "PDF files (*.pdf)|*.pdf|All files (*.*)|*.*";
// Set the filter index to display the PDF filter as the default.
saveFileDialog1.FilterIndex = 2;
// Set the RestoreDirectory property to true so that the SaveFileDialog
// restores the current directory before closing.
saveFileDialog1.RestoreDirectory = true;
// Show the SaveFileDialog and get the result.
if (saveFileDialog1.ShowDialog() == DialogResult.OK)
{
// If the user clicked the OK button in the SaveFileDialog, return the selected file path.
return saveFileDialog1.FileName;
}
// If the user did not click the OK button, return an empty string.
return String.Empty;
}
public string getFilePath()
{
// Create a new instance of the SaveFileDialog class.
SaveFileDialog saveFileDialog1 = new SaveFileDialog();
// Set the initial directory where the SaveFileDialog will open.
saveFileDialog1.InitialDirectory = @"D:\";
// Set the title of the SaveFileDialog.
saveFileDialog1.Title = "Save the PDF Files";
// Set the SaveFileDialog to check if the specified path exists.
saveFileDialog1.CheckPathExists = true;
// Set the default extension for the file type.
saveFileDialog1.DefaultExt = ".pdf";
// Set the filter to display only PDF files or all files.
saveFileDialog1.Filter = "PDF files (*.pdf)|*.pdf|All files (*.*)|*.*";
// Set the filter index to display the PDF filter as the default.
saveFileDialog1.FilterIndex = 2;
// Set the RestoreDirectory property to true so that the SaveFileDialog
// restores the current directory before closing.
saveFileDialog1.RestoreDirectory = true;
// Show the SaveFileDialog and get the result.
if (saveFileDialog1.ShowDialog() == DialogResult.OK)
{
// If the user clicked the OK button in the SaveFileDialog, return the selected file path.
return saveFileDialog1.FileName;
}
// If the user did not click the OK button, return an empty string.
return String.Empty;
}
Public Function getFilePath() As String
' Create a new instance of the SaveFileDialog class.
Dim saveFileDialog1 As New SaveFileDialog()
' Set the initial directory where the SaveFileDialog will open.
saveFileDialog1.InitialDirectory = "D:\"
' Set the title of the SaveFileDialog.
saveFileDialog1.Title = "Save the PDF Files"
' Set the SaveFileDialog to check if the specified path exists.
saveFileDialog1.CheckPathExists = True
' Set the default extension for the file type.
saveFileDialog1.DefaultExt = ".pdf"
' Set the filter to display only PDF files or all files.
saveFileDialog1.Filter = "PDF files (*.pdf)|*.pdf|All files (*.*)|*.*"
' Set the filter index to display the PDF filter as the default.
saveFileDialog1.FilterIndex = 2
' Set the RestoreDirectory property to true so that the SaveFileDialog
' restores the current directory before closing.
saveFileDialog1.RestoreDirectory = True
' Show the SaveFileDialog and get the result.
If saveFileDialog1.ShowDialog() = DialogResult.OK Then
' If the user clicked the OK button in the SaveFileDialog, return the selected file path.
Return saveFileDialog1.FileName
End If
' If the user did not click the OK button, return an empty string.
Return String.Empty
End Function
Hier ist eine Schritt-für-Schritt-Breakdown dessen, was diese Methode tut:
- Die Methode erzeugt eine neue Instanz der Klasse
SaveFileDialog. Diese Klasse ist Teil der Windows Forms-Bibliothek und bietet ein Dialogfeld, das es dem Benutzer ermöglicht, einen Dateipfad auszuwählen, unter dem die PDF-Datei gespeichert wird. - Die Methode legt mehrere Eigenschaften des
SaveFileDialog-Objekts fest, um dessen Verhalten anzupassen. Die EigenschaftInitialDirectorylegt das Verzeichnis fest, in dem das Dialogfeld zuerst geöffnet wird. Die EigenschaftTitlelegt den Titel des Dialogfelds fest. Die EigenschaftCheckPathExistsgibt an, ob das Dialogfeld prüfen soll, ob der angegebene Pfad existiert. Die EigenschaftDefaultExtlegt die Standarddateierweiterung für den Dateityp fest. Die EigenschaftFilterlegt die Dateitypfilter fest, die im Dialogfeld angezeigt werden. Die EigenschaftFilterIndexlegt den Standardfilter fest, der angezeigt werden soll. Schließlich legt die EigenschaftRestoreDirectoryfest, ob das Dialogfeld vor dem Schließen das aktuelle Verzeichnis wiederherstellen soll. - Die Methode zeigt den
SaveFileDialogdurch Aufruf ihrer MethodeShowDialogan. Diese Methode zeigt das Dialogfeld an und gibt einen WertDialogResultzurück, der angibt, ob der Benutzer auf die Schaltfläche "OK" oder auf die Schaltfläche "Abbrechen" geklickt hat. - Wenn der Benutzer auf die Schaltfläche "OK" klickt, gibt die Methode den vom Benutzer ausgewählten Dateipfad zurück, indem sie auf die
FileName-Eigenschaft derSaveFileDialogzugreift. - Wenn der Benutzer die "Abbrechen"-Schaltfläche klickt oder das Dialogfeld schließt, gibt die Methode einen leeren String zurück.
Lassen Sie uns das Projekt ausführen und die Ausgabe sehen. Führen Sie das Projekt aus und das folgende Formular wird geöffnet.
Windows Forms-Projekt ausführen
Geben Sie Ihren PDF-Inhalt ein und klicken Sie auf die "Speichern"-Schaltfläche, wie unten gezeigt.
Speichern-Dialogfeld
Das folgende PDF wird erstellt.
Erstellte PDF-Datei
IronPDF bietet eine einfache Möglichkeit, HTML-Inhalte in PDF-Dokumente umzuwandeln und diese unter einem vom Benutzer ausgewählten Dateipfad zu speichern. Hierfür werden die Klasse ChromePdfRenderer und das Dialogfeld SaveFileDialog verwendet.
Abschluss
Das Speichern von PDF-Dateien aus einer Windows Forms-Anwendung ist eine häufige Anforderung, und IronPDF bietet eine einfach zu verwendende und flexible Methode, um diese Aufgabe zu erledigen. Dieser Artikel zeigte, wie man IronPDF verwendet, um Dateien in einer C# Windows Forms-Anwendung zu erstellen, Inhalte hinzuzufügen und zu speichern. Mit IronPDF können Entwickler hochwertige PDF-Dateien aus ihren Anwendungen mit nur wenigen Codezeilen erstellen.
IronPDF bietet eine Reihe von Funktionen wie HTML-zu-PDF-Konvertierung Tutorial, PDF Zusammenführungs-Beispielcode, Guide zum Aufteilen von PDF-Seiten und Leitfaden zum Extrahieren von Text und Bildern und mehr. IronPDF ist kostenlos für die Entwicklung und steht unter einer kommerziellen Lizenz mit einer kostenlosen Testversion zur Verfügung, die Entwicklern erlaubt, es in kommerziellen Projekten zu verwenden und umfasst dedizierten Support und Updates.
Darüber hinaus ist IronPDF Teil der Iron Suite, einem Paket von .NET-Softwarekomponenten, das Bibliotheken für enthält:
- Barcode-Erzeugung (IronBarcode),
- Excel-Management (IronXL),
- Textextraktion (IronOCR)
[Der Kauf der kompletten Iron Suite](Iron Suite) ist eine kostengünstige Lösung, da Sie alle fünf Produkte zum Preis von zwei erhalten.
Häufig gestellte Fragen
Wie kann ich eine PDF-Datei in einer C# Windows Forms-Anwendung speichern?
Sie können eine PDF-Datei in einer C# Windows Forms-Anwendung speichern, indem Sie ein Formular mit Steuerelementen wie Textfelder und Schaltflächen einrichten und die Methode Save_Click implementieren, um den Inhalt mithilfe der ChromePdfRenderer-Klasse als PDF zu rendern und zu speichern.
Welche Schritte sind erforderlich, um eine Windows Forms-Anwendung zum Speichern von PDFs mit C# einzurichten?
Um eine Windows Forms-Anwendung zum Speichern von PDFs einzurichten, erstellen Sie ein neues Projekt in Visual Studio, fügen Sie die erforderlichen Steuerelemente wie Labels und ein Rich-Text-Feld hinzu und installieren Sie IronPDF über den NuGet-Paket-Manager, um dessen PDF-Rendering-Funktionen nutzen zu können.
Wie kann ich HTML-Inhalte in C# in ein PDF konvertieren?
Sie können HTML-Inhalte in C# in ein PDF konvertieren, indem Sie die Methode RenderHtmlAsPdf von IronPDF verwenden, die es ermöglicht, HTML-Strings direkt in PDF-Dokumente zu rendern.
Welche Rolle spielt die Save_Click-Methode im Kontext der PDF-Erstellung?
Die Save_Click-Methode fungiert als Ereignishandler innerhalb der Anwendung, der für das Erfassen des Klickereignisses einer Schaltfläche verantwortlich ist, um den Prozess des Renderns von Textfeldinhalten in eine PDF-Datei mithilfe der Rendering-Klassen von IronPDF zu initiieren.
Wie kann ich Benutzer dazu auffordern, einen Dateipfad zum Speichern einer PDF-Datei in einer C#-Anwendung auszuwählen?
In einer C#-Anwendung können Sie Benutzer auffordern, einen Dateipfad zum Speichern einer PDF-Datei auszuwählen, indem Sie die SaveFileDialog-Klasse verwenden, die es Ihnen ermöglicht, eine Oberfläche für die Dateiauswahl einzurichten und den ausgewählten Pfad zum Speichern der gerenderten PDF zurückzugeben.
Welche erweiterten Funktionen bietet IronPDF zur PDF-Manipulation?
IronPDF bietet erweiterte Funktionen wie HTML-zu-PDF-Konvertierung, das Zusammenführen von PDFs, das Aufteilen von PDF-Seiten und das Extrahieren von Text und Bildern, wodurch eine umfassende Sammlung von Tools zur PDF-Manipulation in .NET-Anwendungen bereitgestellt wird.
Gibt es Kosten für die Verwendung von IronPDF zur PDF-Erstellung in kommerziellen Projekten?
IronPDF ist mit einer Testlizenz für Entwicklungszwecke kostenlos. Für kommerzielle Projekte ist jedoch eine kommerzielle Lizenz erforderlich, die Vorteile wie dedizierten Support und regelmäßige Updates beinhaltet.
Was ist die Iron Suite und wie profitieren Entwickler davon?
Die Iron Suite ist eine Sammlung von .NET-Bibliotheken, einschließlich Tools für Barcode-Erzeugung, Excel-Dokumentenbearbeitung und PDF-Verarbeitung. Sie bietet eine kostengünstige Lösung für Entwickler, die mehrere Funktionalitäten in ihren Anwendungen benötigen.
Ist IronPDF mit .NET 10 kompatibel und welche Vorteile bietet das für das Speichern von PDFs in C#?
Ja – IronPDF unterstützt .NET 10 vollständig, einschließlich Desktop-, Web- und plattformübergreifender Projekttypen. Die Entwicklung mit .NET 10 bietet Verbesserungen wie eine höhere Laufzeitleistung, Zugriff auf moderne C#-Erweiterungen und eine engere Integration mit Plattformfunktionen. Dadurch wird das Erstellen und Speichern von PDFs mit den IronPDF-Methoden RenderHtmlAsPdf und SaveAs effizienter.




