Renderer – Rendern von HTML, MHTML, EPUB und SVG in Python
Renderer
Der aspose.html.rendering Namespace besteht aus zahlreichen Renderer-Objekten und entsprechenden Low-Level-Optionen-Klassen, die für das Rendering von Dokumenten in der IDevice-Implementierung verantwortlich sind. Aspose.HTML für Python via .NET API bietet die folgende Realisierung von Renderern: HtmlRenderer, SvgRenderer, MhtmlRenderer und EpubRenderer, die jeweils zum Rendern von HTML-, SVG-, MHTML- und EPUB-Dokumenten verwendet werden.
Der vorliegende Artikel beschreibt unterstützte Szenarien der HTML-basierten Dateikonvertierung in andere gängige Formate unter Verwendung von render()
-Methoden des
aspose.html.rendering Namespace.
HtmlRenderer
Die Klasse
HtmlRenderer kann zum Rendern von HTML-Dateien in verschiedene gängige Formate verwendet werden und ermöglicht die Anpassung der Rendering-Optionen und die Kontrolle über die Ausgabe des Prozesses. Betrachten wir die Verwendung der Klasse HtmlRenderer
zum Rendern von HTML in PDF mit benutzerdefinierten Ausgabeeinstellungen:
- Initialisieren Sie ein HTML-Dokument mit der Klasse HTMLDocument.
- Erstellen Sie ein neues HtmlRenderer Objekt.
- Erstellen Sie eine Instanz von
PdfRenderingOptions und passen Sie die Optionen für Ihr PDF-Ausgabedokument an. Sie können zum Beispiel die Eigenschaft
any_page der Klasse
PageSetup
setzen, um ein neues Page-Objekt mit den Abmessungen 600 Pixel mal 200 Pixel zu erstellen. Darüber hinaus können Sie die Eigenschaft encryption konfigurieren, um Benutzer- und Eigentümerpasswörter, zulässige Aktionen und den Verschlüsselungsalgorithmus für die PDF-Ausgabedatei festzulegen. - Verwenden Sie den Konstruktor PdfDevice(options, savePath), um ein Objekt der Klasse PdfDevice zu erstellen.
- Rufen Sie die Methode render(device, document) auf, um HTML in PDF mit den angegebenen Rendering-Optionen zu rendern.
1import os
2import aspose.html as ah
3import aspose.html.rendering as rn
4import aspose.html.rendering.pdf as rp
5import aspose.html.drawing as dr
6import aspose.html.rendering.pdf.encryption as rpe
7
8# Setup input and output directories
9data_dir = "data/"
10output_dir = "output/"
11os.makedirs(output_dir, exist_ok=True)
12
13# Prepare path to the source HTML file
14document_path = os.path.join(data_dir, "document.html")
15
16# Initialize an HTML document from the file
17doc = ah.HTMLDocument(document_path)
18
19# Create an instance of the HTML Renderer
20renderer = rn.HtmlRenderer()
21
22# Prepare path to save the converted PDF
23save_path = os.path.join(output_dir, "render-html-with-options.pdf")
24
25# Create PDF rendering options and set custom page size
26options = rp.PdfRenderingOptions()
27options.page_setup.any_page = dr.Page(dr.Size(600, 200))
28
29# Setup PDF encryption
30options.encryption = rpe.PdfEncryptionInfo(
31 user_password="user_pwd",
32 owner_password="owner_pwd",
33 permissions=rpe.PdfPermissions.PRINT_DOCUMENT,
34 encryption_algorithm=rpe.PdfEncryptionAlgorithm.RC4_128
35)
36
37# Create the PDF device with options and output path
38device = rp.PdfDevice(options, save_path)
39
40# Render HTML to PDF
41renderer.render(device, doc)
Rendering-Optionen geben Ihnen zusätzliche Kontrolle über den Rendering-Prozess. Um mehr über sie zu erfahren, lesen Sie bitte den Artikel Rendering-Optionen.
Weitere Informationen über den Rendering-Prozess finden Sie im Artikel Rendering Device.
SvgRenderer
Mit dem SvgRenderer können Sie SVG-Dateien in andere Dateiformate wie PDF, XPS, DOCX und Bildformate umwandeln. Das folgende Beispiel zeigt, wie die SvgRenderer-Klasse verwendet wird, um SVG in PNG zu rendern, wobei eine benutzerdefinierte Seitengröße angegeben wird:
- Initialisieren Sie ein SVG-Dokument. Verwenden Sie einen der SVGDocument() Konstruktoren, um eine SVGDocument-Instanz zu erstellen.
- Erstellen Sie ein neues SvgRenderer-Objekt.
- Erstellen Sie eine Instanz von ImageRenderingOptions und legen Sie benutzerdefinierte Optionen für das ausgegebene PNG-Bild fest. Im Beispiel geben wir die Eigenschaft any_page an, die ein neues Seitenobjekt mit einer Seitengröße von 400x300 Pixeln festlegt.
- Verwenden Sie den Konstruktor ImageDevice(options, savePath), um ein Objekt der Klasse ImageDevice zu erstellen.
- Aufruf der Methode render(device, document) zum Rendern von SVG in PNG mit den angegebenen Rendering-Optionen.
1import os
2import aspose.html as ah
3import aspose.html.rendering.image as ri
4import aspose.html.rendering as rn
5import aspose.html.drawing as dr
6
7# Setup input and output directories
8data_dir = "data/"
9output_dir = "output/"
10os.makedirs(output_dir, exist_ok=True)
11
12# Prepare path to the source SVG file
13doc_path = os.path.join(data_dir, "flower.svg")
14save_path = os.path.join(output_dir, "render-svg-with-options.png")
15
16# Initialize an SVG document from the file
17doc = ah.dom.svg.SVGDocument(doc_path)
18
19# Create an instance of the SVG Renderer
20renderer = rn.SvgRenderer()
21
22# Create the instance of Rendering Options and set a custom page-size
23options = ri.ImageRenderingOptions()
24options.page_setup.any_page = dr.Page(dr.Size(400, 300))
25
26# Create the PNG device with options and output path
27device = ri.ImageDevice(options, save_path)
28
29# Render SVG to PNG
30renderer.render(device, doc)
MhtmlRenderer
Dieses Beispiel veranschaulicht die Konvertierung eines MHTML-Dokuments in PDF unter Verwendung der Klasse MhtmlRenderer mit bestimmten Rendering-Optionen:
- Öffnen Sie ein vorhandenes MHTML-Dokument.
- Erstellen Sie eine Instanz der MhtmlRenderer-Klasse mit dem MhtmlRenderer() Konstruktor.
- Initialisieren Sie die Klasse PdfRenderingOptions und legen Sie Rendering-Optionen fest.
- Erstellen Sie eine Instanz der Klasse PdfDevice.
- Rufen Sie die Methode render(device, stream) auf, um MHTML in PDF umzuwandeln.
1import os
2import aspose.html.rendering.pdf as rp
3import aspose.html.rendering as rn
4import aspose.html.drawing as dr
5import aspose.pydrawing as pd
6
7# Setup input and output directories
8data_dir = "data/"
9output_dir = "output/"
10os.makedirs(output_dir, exist_ok=True)
11
12# Prepare path to the source MHTML file
13epub_path = os.path.join(data_dir, "document.mht")
14save_path = os.path.join(output_dir, "render-mhtml-with-options.pdf")
15
16# Open the MHTML file in binary mode
17with open("document.mht", 'rb') as stream:
18
19 # Create an instance of MHTML Renderer
20 renderer = rn.MhtmlRenderer()
21
22 # Create PDF rendering options and set a custom page size
23 options = rp.PdfRenderingOptions()
24 options.page_setup.any_page = dr.Page(dr.Size(800, 400))
25 options.background_color = pd.Color.bisque
26
27 # Create an instance of PdfDevice for output
28 device = rp.PdfDevice(options, save_path)
29
30 # Render MHTML to PDF
31 renderer.render(device, stream)
EpubRenderer
Mit der Klasse EpubRenderer können Sie EPUB-Dateien in andere Formate wie PDF, XPS, DOCX und Bilder konvertieren. Die folgenden Python-Beispiele zeigen, wie EPUB in DOCX mit einer benutzerdefinierten Seitengrößeneinstellung konvertiert werden kann:
- Öffnen Sie eine vorhandene EPUB-Datei.
- Erstellen Sie eine Instanz der EpubRenderer-Klasse.
- Initialisieren Sie die Klasse DocRenderingOptions und legen Sie Rendering-Optionen fest.
- Erstellen Sie eine Instanz der Klasse DocDevice.
- Rufen Sie die Methode render(device, stream) auf, um EPUB in DOCX umzuwandeln.
1import os
2import aspose.html.rendering.doc as rd
3import aspose.html.rendering as rn
4import aspose.html.drawing as dr
5
6# Setup input and output directories
7data_dir = "data/"
8output_dir = "output/"
9os.makedirs(output_dir, exist_ok=True)
10
11# Prepare path to the source EPUB file
12epub_path = os.path.join(data_dir, "input.epub")
13save_path = os.path.join(output_dir, "render-epub-with-options.docx")
14
15# Open the EPUB file in binary mode
16with open(epub_path, "rb") as stream:
17
18 # Create an instance of EPUB Renderer
19 renderer = rn.EpubRenderer()
20
21 # Create DOC rendering options and set a custom page size
22 options = rd.DocRenderingOptions()
23 options.page_setup.any_page = dr.Page(dr.Size(800, 400))
24
25 # Create an instance of DocDevice for output
26 device = rd.DocDevice(options, save_path)
27
28 # Render EPUB to DOCX
29 renderer.render(device, stream)
Aspose.HTML bietet kostenlose Online- Konverter, die HTML-, XHTML-, MHTML-, EPUB-, XML- und Markdown-Dateien in eine Reihe von gängigen Formaten konvertieren können. Sie können Ihre HTML-basierten Dokumente ganz einfach in PDF, XPS, DOCX, JPG, PNG, GIF, TIFF und andere konvertieren. Wählen Sie einfach eine Datei und das zu konvertierende Format aus, und schon sind Sie fertig.