Pdf: Python Khmer
c = canvas.Canvas("khmer_sample.pdf", pagesize=A4) c.setFont('KhmerFont', 14) c.drawString(100, 750, "សួស្តីពិភពលោក") # "Hello World" in Khmer c.save() ⚠️ Ensure the TrueType font supports Khmer and is placed in your working directory. fpdf2 can embed Unicode fonts, but complex scripts like Khmer often break due to lack of proper shaping.
import cairo import pangocairo surface = cairo.PDFSurface("shaped_khmer.pdf", 200, 100) context = cairo.Context(surface) pangocairo_context = pangocairo.CairoContext(context) pangocairo_context.set_antialias(cairo.ANTIALIAS_SUBPIXEL)
from pypdf import PdfReader reader = PdfReader("khmer_document.pdf") for page in reader.pages: print(page.extract_text()) Khmer requires reordering of vowels and diacritics. Use pyftsubset + harfbuzz (via weasyprint or cairo ) for proper shaping. python khmer pdf
y = 800 for key, value in content.items(): c.drawString(50, y, f"key: value") y -= 20
from reportlab.pdfgen import canvas from reportlab.lib.pagesizes import A4 from reportlab.pdfbase import pdfmetrics from reportlab.pdfbase.ttfonts import TTFont pdfmetrics.registerFont(TTFont('KhmerFont', 'KhmerOSBattambang-Regular.ttf')) c = canvas
Example using cairo and Pango (Linux/macOS):
Use weasyprint or xhtml2pdf with HTML/CSS that already handles Khmer shaping. 2. Extracting Text from Khmer PDFs Using PyMuPDF (fitz) PyMuPDF handles Khmer Unicode extraction well. Use pyftsubset + harfbuzz (via weasyprint or cairo
from fpdf import FPDF pdf = FPDF() pdf.add_page() pdf.add_font('khmer', '', 'KhmerOS.ttf', uni=True) pdf.set_font('khmer', size=12) pdf.cell(0, 10, txt="ជំរាបសួរ", ln=1) pdf.output("fpdf_khmer.pdf")