• 公众号数据采集、抖音视频采集、视频号数据采集

分享一个批量把网页保存为pdf的方法

公众号 kakalong 1年前 (2023-01-31) 3323次浏览 0个评论 扫描二维码
大家过年好,新的一年我们都要加油呀。
这不,前几天想把 vue 官网的资料打印出来慢慢学习,作为一个技术流懒人,我就想能不能让程序自动帮我完成这个工作,研究了一下不算复杂,很快就保存完成了。

分享一个批量把网页保存为 pdf 的方法

而且这个思路有一定的通用性,也许做些修改就适用于其他类似结构的网站,所以想分享给大家一起讨论学习,如果您测试成功了其他网站欢迎留言跟大家分享您的心得。
此项目的关键是使用 playwright 库,这是一个微软推出的类似于 selenium 的网页自动化工具库,能自动化控制 chrome,功能强大,参考资料齐全,内置了网页转 pdf 等功能。此库的帮助文档非常详细,网址列在了最下方,基本的安装和使用方法就不再赘述。
主要步骤:
  1. 获取所有帮助文档的链接,这个比较容易,手动从 vue 官网的侧边栏保存即可,参考下图,把包含所有网页列表的 html 源代码保存为 vuelist.txt。
  2. 使用 BeautifulSoup 库从 html 中提取所有网页的链接,逐个打开。
  3. 对每个网页执行一段 js 去掉最上方固定层,避免有部分文字被覆盖。
  4. 将网页转化为 pdf,并以序号+标题的形式保存。
 
 
以下是所有代码,话说程序真是个好东西,能自我解释,没有歧义性,还能专治各种不服(错一点就得不到正确结果,任你重试多少遍)。
import os,sys
import playwright
from playwright.sync_api import sync_playwright
from time import sleep
from bs4 import BeautifulSoup
​
'''
1.如果选择“组合式”,需在打开第一页时手动在网页中点一下
2.vuelist.txt 是通过 chrome 开发者工具中手动复制保存侧边栏文章列表相关的 html 实现,即选择 <nav id="VPSidebarNav" 
3.vue 官网的设计比较好,打印为 pdf 只打正文内容,但打其他网站时可能需要酌情调整,比如先执行自定义 js
参考网址 https://playwright.dev/python/docs/api/class-page
'''
​
jstxt = 'document.getElementsByClassName("VPNav nav-bar")[0].remove()'
pageMode = "A4" #对应纸的尺寸,
​
​
#读取 txt 文件
def ReadFile(filepath):
    with open(filepath, 'r', encoding='utf-8') as f:
        all_the_text = f.read()
    return all_the_text
​
def Run():
    with sync_playwright() as p:
        browser = p.chromium.launch(headless=False)
        page = browser.new_page()
        page.set_default_timeout(20000) #设置网页加载超时时间
​
        page.emulate_media(media="screen")
        txt = ReadFile("vuelist.txt")
        bsobj = BeautifulSoup(txt,"lxml")
        all_a = bsobj.findAll("a")
        idx = 0
        for item in all_a:
            url = item.attrs.get('href')
            if url is None or len(url) < 2:#某些 a 标签可能没有 href
                continue
            url = "https://cn.vuejs.org" + url #相对 url 需要补全
            title = item.get_text()
            if "?" in title: #处理标题中有特殊字符的,不一定要略过
                continue
            print(idx,title,url) #方便查看实时进度
            idx += 1
​
            pdfname = pageMode + "_" + str(idx) + "_" + title + ".pdf" #我习惯这样命名,方便排序和查看,您也可以自行修改
            if os.path.exists(pdfname): #程序运行时有可能中断,重新开始时略过已经保存的
                continue
            page.goto(url)
            sleep(5)
            page.evaluate(jstxt)#执行 js,把最上方的固定层删除,否则生成的文档中会有部分内容丢失
            sleep(2)
            page.pdf(path = pdfname, format = pageMode,margin={"top":"28px","bottom":"28px"}) #还有许多可以设置的参数,详见参考网址
​
​
if __name__=="__main__":
    Run()
 
 
多个 pdf 合并可以使用 foxit 的pdf 编辑器,注意不是阅读器。
最后,虽然 vue 官网是个大站,咱也不要给人家造成太大压力,所以程序中用了 sleep 函数,大家也不要爬太多次,毕竟是以学习为主。
参考网址
  1. vue 官网教程 https://cn.vuejs.org/guide/introduction.html
  2. playwright 官网 https://playwright.dev/python/docs/api/class-page
  3. pdf 合并软件 https://editor.foxitsoftware.cn/?agent=foxit&MD=menu
 

下面是我开发的其他小工具,欢迎使用

如何快速保存一篇公众号文章

超炫的微信群全家福一键生成器

[小工具]抖音视频批量下载软件


本文标题:分享一个批量把网页保存为 pdf 的方法
转载请保留页面地址 https://www.xiaokuake.com/p/html2pdf.html
喜欢 (0)
发表我的评论
取消评论
表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址