【URL 转换为PDF】HTML转换为PDF

1、方法1 pdfkit

安装依赖

python 复制代码
# 安装 wkhtmltopdf(系统级)
# Ubuntu/Debian
sudo apt install wkhtmltopdf

# macOS
brew install wkhtmltopdf

# Windows 下载安装:https://wkhtmltopdf.org/downloads.html

# 安装 Python 库
pip install pdfkit
python 复制代码
import pdfkit

# 将网页转为 PDF
def url_to_pdf(url, output_path):
    try:
        pdfkit.from_url(url, output_path)
        print(f"PDF 已保存为: {output_path}")
    except Exception as e:
        print(f"转换失败: {e}")

# 示例调用(替换为你的链接)
url_to_pdf(
    "https://etcnew.sdut.edu.cn/meol/common/script/preview/download_preview.jsp?fileid=15400633&resid=1451996&lid=65791&preview=preview",
    "水泥工艺学-第五章硅酸盐水泥熟料的煅烧.pdf"
)

方法2:pyppeteer (很高级)适用于JavaScript渲染的网页(如Vue、React页面)。

python 复制代码
import asyncio
from pyppeteer import launch

async def html_to_pdf(url, output_path):
    browser = await launch(headless=True)
    page = await browser.newPage()
    await page.goto(url, {'waitUntil': 'networkidle2'})
    await page.pdf({'path': output_path, 'format': 'A4', 'printBackground': True})
    await browser.close()

# 使用示例
asyncio.run(html_to_pdf("https://example.com", "output.pdf"))

方法3:playwright (最高级,最稳定版本)

python 复制代码
# 更新 pip
python3 -m pip install -U pip

# 安装 Playwright Python 库
pip install playwright

# 下载并安装所需的浏览器(Chromium、Firefox、WebKit)
playwright install


playwright --version
python 复制代码
from playwright.sync_api import sync_playwright

with sync_playwright() as p:
    browser = p.chromium.launch(headless=True)
    page = browser.new_page()
    page.goto("https://example.com")
    page.pdf(path="page.pdf", format="A4")
    browser.close()
相关推荐
毕设十刻12 小时前
基于Vue的考勤管理系统8n7j8(程序 + 源码 + 数据库 + 调试部署 + 开发环境配置),配套论文文档字数达万字以上,文末可获取,系统界面展示置于文末
前端·数据库·vue.js
coding随想12 小时前
掌控选区的终极武器:getSelection API的深度解析与实战应用
java·前端·javascript
嵌入式小能手12 小时前
飞凌嵌入式ElfBoard-文件I/O的深入学习之存储映射I/O
java·前端·学习
沐风。5612 小时前
Object方法
开发语言·前端·javascript
程序猿小蒜13 小时前
基于springboot的医院资源管理系统开发与设计
java·前端·spring boot·后端·spring
仙人掌一号13 小时前
梳理SPA项目Router原理和运行机制 [共2500字-阅读时长10min]
前端·javascript·react.js
粥里有勺糖13 小时前
视野修炼-技术周刊第128期 | Bun 被收购
前端·javascript·github
用户120391129472614 小时前
彻底搞定大模型流式输出:从二进制碎块到“嘚嘚嘚”打字机效果,让底层逻辑飞起来
前端·javascript·面试
CPU NULL14 小时前
Vue 3 前端调试与开发指南
前端·javascript·vue.js
幼儿园技术家15 小时前
多方案统一认证体系对比
前端