如何使用Python生成PDF?

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

使用Python生成PDF有多种方式,最常用的是通过 ReportLab 库,它功能强大且支持高度自定义。此外,也可以结合HTML模板使用 weasyprintpdfkit(基于wkhtmltopdf)来生成更美观的PDF文档。

1. 使用 ReportLab 生成基础PDF

ReportLab 是生成PDF最流行的库之一,适合创建包含文本、图形、表格等内容的PDF。

安装方法:

pip install reportlab

示例代码:生成一个简单的PDF

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 HTML

html = '

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。