Files
egutierrez 0819c35bbb feat: issue/0020 — generacion de PDFs en Python y Go
Añade 3 tipos Python (PDFDoc, PDFPage, PDFStyle) y 10 funciones Python
para construir PDFs con fpdf2 (builder fluent), fusionar PDFs con pypdf
y convertir HTML/Markdown a PDF via weasyprint (stub si no disponible).
Añade pdf_simple_report en Go como stub hasta que go-pdf/fpdf se integre.

- python/types/infra/: pdf_doc, pdf_page, pdf_style
- python/functions/infra/: pdf_create, pdf_add_page, pdf_add_text,
  pdf_add_table, pdf_add_image, pdf_add_header_footer, pdf_from_html,
  pdf_from_markdown, pdf_merge, pdf_save
- functions/infra/pdf_simple_report.go: stub Go con ReportSection/ReportTable
- 17 tests Python pasando (pytest)
- fpdf2 y pypdf añadidos via uv al venv Python

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
2026-04-13 02:02:51 +02:00

50 lines
1.6 KiB
Python

"""pdf_from_html — convierte HTML string a PDF usando weasyprint (stub si no disponible)."""
def pdf_from_html(
html_string: str,
output_path: str,
page_size: str = "A4",
css: str = "",
) -> str:
"""Convierte un HTML string a PDF usando weasyprint.
Soporta CSS inline y externo (pasado como string). Produce PDFs de alta
calidad tipografica con soporte completo de CSS layout (columnas, grids,
fuentes web).
NOTA: Requiere weasyprint y sus dependencias de sistema (pango, cairo,
gdk-pixbuf). Instalar con: pip install weasyprint
En Linux: apt install libpango-1.0-0 libcairo2 libgdk-pixbuf-2.0-0
Args:
html_string: contenido HTML completo como string.
output_path: ruta donde guardar el PDF generado.
page_size: tamaño de pagina CSS: 'A4', 'letter', 'A3'. Por defecto 'A4'.
css: CSS adicional como string para aplicar sobre el HTML.
Returns:
output_path con el PDF guardado.
Raises:
RuntimeError: si weasyprint no esta instalado.
"""
try:
import weasyprint
except ImportError as exc:
raise RuntimeError(
"weasyprint no esta instalado. "
"Instalar con: pip install weasyprint\n"
"Dependencias de sistema (Linux): "
"apt install libpango-1.0-0 libcairo2 libgdk-pixbuf-2.0-0"
) from exc
page_css = f"@page {{ size: {page_size}; }}"
full_css = page_css + "\n" + css if css else page_css
html = weasyprint.HTML(string=html_string)
stylesheet = weasyprint.CSS(string=full_css)
html.write_pdf(output_path, stylesheets=[stylesheet])
return output_path