Convert Markdown → PDF via Pandoc + XeLaTeX. Full LaTeX math + CJK support.
System packages (apt):
pandoc texlive-xetex texlive-fonts-recommended texlive-fonts-extra texlive-latex-extra texlive-lang-chinese
bash <skill_dir>/scripts/md2pdf.sh input.md output.pdf
The script auto-detects CJK content, picks suitable fonts, sanitizes emoji, adds TOC, and configures XeLaTeX.
For fine-grained control, run pandoc directly:
pandoc input.md -o output.pdf \
--pdf-engine=xelatex \
-f markdown-smart \
-H header.tex \
-V mainfont="DejaVu Sans" \
-V monofont="DejaVu Sans Mono" \
-V geometry:margin=20mm \
-V fontsize=10pt \
-V colorlinks=true \
--highlight-style=tango \
--toc -V toc-title="Table of Contents"
Where header.tex contains:
\usepackage{xeCJK}
\setCJKmainfont{<CJK font name>}
$...$ (inline) and $$...$$ (display) to LaTeX math. No MathJax/KaTeX needed.✅ → [Y], ❌ → [N], ⭐ → *) since most LaTeX fonts lack emoji glyphs.-f markdown-smart to avoid curly quote rendering issues.longtable LaTeX package.| Problem | Fix |
|---|---|
| --------- | ----- |
| Missing character warnings | Check fc-list :lang=zh for available CJK fonts; install fonts-noto-cjk if needed |
xelatex not found | Install texlive-xetex |
| PDF has no math rendering | Ensure markdown uses $...$ / $$...$$ (not HTML math tags) |
| Broken table layout | Simplify table or add -V geometry:margin=15mm for more width |
共 1 个版本