V2EX = way to explore
V2EX 是一个关于分享和探索的地方
Sign Up Now
For Existing Member  Sign In
qsnow6
V2EX  ›  问与答

HTML 转 PDF 有什么来源的解决方案吗

  •  
  •   qsnow6 · Jan 18, 2018 via iPhone · 2483 views
    This topic created in 3021 days ago, the information mentioned may be changed or developed.

    看到那个用 WORD 筛选简历的帖子,想起这个需求。

    之前谷歌到一款付费的 api,但是很坑爹

    1. 一个月 30 刀
    2. 限制请求次数
    3. 当月没用完就清零

    今天登陆账号一看,清零了,心疼之前没用完的配额,不知道有来源的解决方案吗,html 转 pdf 有什么难点?

    18 replies    2018-01-19 09:02:52 +08:00
    undeflife
        1
    undeflife  
       Jan 18, 2018   ❤️ 2
    自建后端 使用 wkhtmltopdf
    也有前端转 pdf 的方案 也就是 html->canvas->image->pdf 效果不好:文件尺寸大、不清晰等问题
    如果倾向第三方 api 的话 https://www.sejda.com/html-to-pdf 我试过效果还不错
    lozzow
        2
    lozzow  
       Jan 19, 2018 via Android
    chrome,打印,另存为 PDF 不可以么
    Tink
        3
    Tink  
    PRO
       Jan 19, 2018 via iPhone
    打印
    4BVL25L90W260T9U
        4
    4BVL25L90W260T9U  
       Jan 19, 2018 via Android
    pandoc
    qsnow6
        5
    qsnow6  
    OP
       Jan 19, 2018 via iPhone
    @Tink #3 @lozzow #2 打印没办法自动化啊,每个月有几十份要转


    @undeflife #1 我试试 WKHTMLTOPDF

    之前我用的第三方 api 是 https://pdfcrowd.com 效果还行,就是付费策略太坑
    herozhang
        6
    herozhang  
       Jan 19, 2018
    chrome,打印,另存为 PDF 不可以么
    shiny
        7
    shiny  
    PRO
       Jan 19, 2018   ❤️ 2
    Headless Chrome 支持直接创建 pdf
    https://github.com/GoogleChrome/puppeteer
    搜索 pdf 有示例代码。
    yangxiongguo
        8
    yangxiongguo  
       Jan 19, 2018 via Android
    按按按键键键精灵,另外 7 楼是最好的方案
    geelaw
        9
    geelaw  
       Jan 19, 2018   ❤️ 2
    可以自动化 IE 的打印功能。

    大概思路:

    $PdfPrinter = @(Get-WmiObject -Class Win32_Printer | Where-Object Name -Like '*pdf*')
    If ($PdfPrinter.Count -ne 1)
    {
    Write-Error '有多个 PDF 打印机或者没有 PDF 打印机'
    exit
    }
    # 设置 Microsoft Print to PDF 为默认打印机
    $PdfPrinter[0].SetDefaultPrinter()

    # 打开 IE
    $IE = New-Object -ComObject InternetExplorer.Application
    $IE.Navigate('https://geelaw.blog/')

    # 等 IE 加载完毕
    While ($IE.Busy) { Start-Sleep 1; }

    # 生成一个文件名
    $FileName = [System.IO.Path]::Combine($env:TMP, [System.Guid]::NewGuid().ToString('n') + '.pdf')

    # 准备一个脚本对象
    $WSh = New-Object -ComObject WScript.Shell

    # 用默认打印机打印
    $IE.ExecWB(6, 2)

    # 这里的等待时间需要动态调整才行,等保存对话框弹出来
    Start-Sleep 1;

    # 复制文件名,按 Ctrl+V,再按 Enter
    $FileName | Set-Clipboard
    $WSh.SendKeys('^V{ENTER}')

    # 需要动态调整,等打印完成
    Start-Sleep 1

    # 关掉 IE
    $IE.Quit()

    # 打开保存的文件
    $FileName | Invoke-Item

    你可以使用可以编程设置保存位置的打印机来更好地自动化保存的位置(似乎 Adobe PDF Printer 是可以的)。
    ysc3839
        10
    ysc3839  
       Jan 19, 2018
    @geelaw 刚才试了一下,选择位置的对话框是在当前进程中的。那可以自己程序里调用 WebBrowser 打印,同时 Hook 一下相关 API,直接返回对应的位置。
    binux
        11
    binux  
       Jan 19, 2018   ❤️ 1
    ysc3839
        12
    ysc3839  
       Jan 19, 2018
    @geelaw 刚才调试了一下,确实会调用 GetSaveFileNameW,那就好办了。
    ysc3839
        13
    ysc3839  
       Jan 19, 2018
    关于网页兼容性。
    wkhtmltopdf 用的是 QtWebKit。
    刚才我说的调用 WebBrowser 还有些坑,要改个注册表来使用新版本的 IE 内核,否则会使用 IE7 的内核。
    另外 Win10 的话有办法调用 Edge 的内核。
    论通用性兼容性,Headless Chrome 是最好的。
    GreatMartial
        14
    GreatMartial  
       Jan 19, 2018 via Android
    simple PDF
    yingfengi
        15
    yingfengi  
       Jan 19, 2018 via Android
    打印成 PDF
    xycool
        16
    xycool  
       Jan 19, 2018
    试试 Puppeteer ?
    murmur
        17
    murmur  
       Jan 19, 2018
    感觉 chrome 的打印功能很好用
    Tink
        18
    Tink  
    PRO
       Jan 19, 2018
    @qsnow6 #5 无头 chrome 不行吗
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   3177 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 65ms · UTC 00:27 · PVG 08:27 · LAX 17:27 · JFK 20:27
    ♥ Do have faith in what you're doing.