Renderers – Rendre HTML, MHTML, EPUB et SVG en Python

Renderers

L’espace de noms aspose.html.rendering comprend de nombreux objets de rendu et des classes d’options de bas niveau appropriées, qui sont responsables du rendu des documents dans l’implémentation IDevice. Aspose.HTML for Python via .NET API fournit la réalisation suivante d’objets de rendu : HtmlRenderer, SvgRenderer, MhtmlRenderer, et EpubRenderer, qui sont utilisés pour rendre les documents HTML, SVG, MHTML, et EPUB, respectivement.

Cet article décrit des scénarios de conversion de fichiers HTML vers d’autres formats populaires à l’aide des méthodes render() de l’espace de noms aspose.html.rendering.

HtmlRenderer

La classe HtmlRenderer peut être utilisée pour rendre des fichiers HTML dans divers formats populaires, permettant de personnaliser les options de rendu et de contrôler le résultat du processus. Voyons comment utiliser la classe HtmlRenderer pour rendre HTML en PDF avec des paramètres de sortie personnalisés :

  1. Initialiser un document HTML en utilisant la classe HTMLDocument.
  2. Créer un nouvel objet HtmlRenderer.
  3. Créez une instance de la classe PdfRenderingOptions et personnalisez les options de votre document PDF de sortie. Par exemple, vous pouvez définir la propriété any_page de la classe PageSetup pour créer un nouvel objet Page avec des dimensions de 600 pixels par 200 pixels. En outre, vous pouvez configurer la propriété encryption, en spécifiant les mots de passe de l’utilisateur et du propriétaire, les actions autorisées et l’algorithme de cryptage pour le fichier PDF de sortie.
  4. Utilisez le constructeur PdfDevice(options, savePath) pour créer un objet de la classe PdfDevice.
  5. Appeler la méthode render(device, document) pour rendre HTML en PDF avec les options de rendu spécifiées.
 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)

Les options de rendu vous donnent un contrôle supplémentaire sur le processus de rendu. Pour en savoir plus, lisez l’article Options de rendu.

Pour en savoir plus sur le processus de rendu, voir l’article Dispositif de rendu.

SvgRenderer

La classe SvgRenderer vous permet de convertir des fichiers SVG en d’autres formats de fichiers, tels que PDF, XPS, DOCX et des formats d’images. L’exemple suivant montre comment utiliser la classe SvgRenderer pour convertir un fichier SVG en PNG en spécifiant une taille de page personnalisée :

  1. Initialiser un document SVG. Utilisez l’un des constructeurs SVGDocument() pour créer une instance de SVGDocument.
  2. Créer un nouvel objet SvgRenderer.
  3. Créez une instance de ImageRenderingOptions et définissez des options personnalisées pour l’image PNG de sortie. Dans l’exemple, nous spécifions la propriété any_page qui définit un nouvel objet Page avec une taille de page de 400x300 pixels.
  4. Utilisez le constructeur ImageDevice(options, savePath) pour créer un objet de la classe ImageDevice.
  5. Appeler la méthode render(device, document) pour rendre SVG en PNG avec les options de rendu spécifiées.
 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

Cet exemple illustre comment convertir un document MHTML en PDF en utilisant la classe MhtmlRenderer avec les options de rendu spécifiées :

  1. Ouvrir un document MHTML existant.
  2. Créez une instance de la classe MhtmlRenderer en utilisant le constructeur MhtmlRenderer().
  3. Initialiser la classe PdfRenderingOptions et définir les options de rendu.
  4. Créer une instance de la classe PdfDevice.
  5. Appelez la méthode render(device, stream) pour convertir le MHTML en PDF.
 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

La classe EpubRenderer vous permet de convertir des fichiers EPUB en d’autres formats tels que PDF, XPS, DOCX et images. L’exemple Python suivant montre comment convertir un fichier EPUB en DOCX avec un paramètre de taille de page personnalisé :

  1. Ouvrir un fichier EPUB existant.
  2. Créer une instance de la classe EpubRenderer.
  3. Initialiser la classe DocRenderingOptions et définir les options de rendu.
  4. Créer une instance de la classe DocDevice.
  5. Appeler la méthode render(device, stream) pour convertir l’EPUB en DOCX.
 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 propose des Convertisseurs gratuits en ligne qui permettent de convertir des fichiers HTML, XHTML, MHTML, EPUB, XML et Markdown dans toute une série de formats populaires. Vous pouvez facilement convertir vos documents HTML en PDF, XPS, DOCX, JPG, PNG, GIF, TIFF et autres. Il vous suffit de sélectionner un fichier, de choisir le format à convertir et le tour est joué.

Texte “Convertisseurs gratuits en ligne”

Subscribe to Aspose Product Updates

Get monthly newsletters & offers directly delivered to your mailbox.