Python Khmer Pdf 🆕 Trending
Example using cairo and Pango (Linux/macOS):
layout = pangocairo_context.create_layout() layout.set_text("កម្ពុជា") layout.set_font_description(pango.FontDescription("Khmer OS 12"))
y = 800 for key, value in content.items(): c.drawString(50, y, f"key: value") y -= 20
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. python khmer pdf
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")
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.
import pdfplumber with pdfplumber.open("khmer_document.pdf") as pdf: for page in pdf.pages: text = page.extract_text() print(text) Works for basic extraction but may fail with complex Khmer glyph order. Example using cairo and Pango (Linux/macOS): layout =
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.
create_khmer_report("data.yaml", "report.pdf") This guide gives you a complete foundation for handling tasks — from creation and extraction to rendering and OCR. Always test with real Khmer text and use fonts that support the full Unicode range for Khmer (U+1780 to U+17FF, plus U+19E0–U+19FF).
Khmer script (អក្សរខ្មែរ) presents unique challenges when generating or extracting PDFs programmatically. Unlike Latin-based scripts, Khmer requires correct rendering of subscripts, diacritics, and vowel ordering. Python offers several libraries to handle these tasks, but careful font and encoding choices are critical. 1. Generating PDFs with Khmer Text Using reportlab Reportlab is a powerful PDF generation library, but it does not natively support complex script shaping. To generate correct Khmer PDFs: encoding="utf-8") as f: yaml.dump(data
c.save() data = "ចំណងជើង": "របាយការណ៍ប្រចាំឆ្នាំ", "កាលបរិច្ឆេទ": "២០២៥-០៣-០១"
with open("data.yaml", "w", encoding="utf-8") as f: yaml.dump(data, f, allow_unicode=True)
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)
pangocairo_context.update_layout(layout) pangocairo_context.show_layout(layout) surface.finish() For scanned Khmer PDFs, convert to images then use Tesseract with Khmer language pack.