使用ReportLab可生成含文本、图形的PDF,适合基础需求;2. 通过pdfkit结合HTML/CSS生成视觉美观的PDF,需安装wkhtmltopdf;3. WeasyPrint支持现代CSS,推荐用于复杂样式如报表;4. 注意中文乱码、路径及样式兼容性问题,按需选择工具。

使用Python生成PDF有多种方式,最常用的是通过 ReportLab 库,它功能强大且支持高度自定义。此外,也可以结合HTML模板使用 weasyprint 或 pdfkit(基于wkhtmltopdf)来生成更美观的PDF文档。
1. 使用 ReportLab 生成基础PDF
ReportLab 是生成PDF最流行的库之一,适合创建包含文本、图形、表格等内容的PDF。
安装方法:pip install reportlab
示例代码:生成一个简单的PDF
立即学习“Python免费学习笔记(深入)”;
from reportlab.pdfgen import canvas创建PDF文件
pdf = canvas.Canvas("example.pdf") pdf.setTitle("示例PDF")
添加文字
pdf.drawString(100, 750, "Hello, 这是一个用Python生成的PDF!") pdf.drawString(100, 730, "你还可以添加更多内容,比如坐标、图像和表格。")
保存
pdf.save()
这段代码会生成名为 example.pdf 的文件,包含两行文字。
2. 使用 pdfkit 从HTML生成PDF
如果你熟悉HTML/CSS,可以先写好页面,再转成PDF,视觉效果更佳。
安装方法:pip install pdfkit
还需要安装 wkhtmltopdf 工具(去官网下载并配置路径)
示例代码:
import pdfkit直接从字符串生成PDF
html_content = """
标题
这是一段用HTML写的正文内容。
- 项目一
- 项目二
pdfkit.from_string(html_content, 'output.pdf')
3. 使用 WeasyPrint(推荐用于复杂样式)
WeasyPrint 支持现代CSS,适合生成带样式、布局复杂的PDF,如报表、简历等。
安装方法:pip install weasyprint
示例代码:
from weasyprint import HTMLhtml = '
Hello from WeasyPrint
支持中文和CSS样式。
' HTML(string=html).write_pdf('weasy_output.pdf')还可以传入HTML文件路径或URL:
HTML(filename='template.html').write_pdf('styled.pdf')4. 常见注意事项
生成PDF时容易遇到的问题包括:
- 中文乱码:确保字体支持,WeasyPrint 可通过CSS指定本地中文字体
- 路径问题:使用绝对路径避免文件找不到
- 样式不生效:pdfkit 对CSS支持有限,WeasyPrint 更完整
基本上就这些。根据需求选择合适的方法:简单文本用 ReportLab,美观排版用 WeasyPrint 或 pdfkit。










