发票PDF在线合并小工具

发票PDF在线合并小工具

月光魔力鸭

2020-12-24 00:28 阅读 52 喜欢 1 发票合并 PDF合并 在线合并PDF

在公司报销的时候虽然已经有了电子发票,但是贴票还是需要将发票打印出来贴上,如果只有一两张也就算了,如果几十张.. 呵呵,光胶水我都不够用的,找了好多工具、在线版本都不合心意,烦死,自己做个自己喜欢的吧。 二次更新 : 发票PDF在线合并来啦 查了下lib库,看了下API 开干。

准备

文档准备

本来想着,将pdf读成图片然后缩放在一个PDF中,结果发现pdf-lib直接就可以将pdf进行缩放,到时省事了。

pdf-lib github地址: https://github.com/Hopding/pdf-lib

代码

这里用到的API很少,主要有以下几个:

embedPdf  :  嵌入PDF文档 
scale           :  将PDF进行缩放    
addPage    :  添加一个新的pdf页面
drawPage  : 将PDF写入新pdf页面

完整代码:

/**
 * 年底,将12个月份的发票合并在一个pdf中。
 * ps.在线的各种不中意,线下的各种收费加水印。
 * npm i pdf-lib
 */
const pdfLib = require('pdf-lib')
const PDFDocument = pdfLib.PDFDocument
// import { PDFDocument } from 'pdf-lib'
const fs = require('fs')
const path = require('path')
//这里需要修改为自己的路径
const folderPath = `I:\\huafei\\huafei\\2020pdf`
  ; (async function () {
    // Create a new PDFDocument
    const pdfDoc = await PDFDocument.create()
    // Add a blank page to the document
    let page = pdfDoc.addPage()

    let lineNum = 1 //每行几张发票

    let fileList = fs.readdirSync(folderPath)
    let i = 0
    fileList.sort((a, b) => {
      let aa = path.basename(a)
      let bb = path.basename(b)
      return aa - bb
    })
    for (let file of fileList) {
      let filePath = path.join(folderPath, file)
      let fileStream = fs.readFileSync(filePath)
      const [americanFlag] = await pdfDoc.embedPdf(fileStream)
      const dims = americanFlag.scale(1 / lineNum)
      // Draw the JPG image in the center of the page
      let opts = {
        ...dims,
        x: (i % lineNum) * (dims.width - 20) - 5,
        y:
          page.getHeight() -
          Math.floor(i / lineNum) * (dims.height + 5) -
          dims.height,
      }
      //如果当前高度不足,则创建新页面
      console.log(opts)
      if (opts.y < 0) {
        //换页面
        page = pdfDoc.addPage()
        i = 0
        opts = {
          ...dims,
          x: (i % lineNum) * (dims.width - 20) - 5,
          y:
            page.getHeight() -
            Math.floor(i / lineNum) * (dims.height + 5) -
            dims.height,
        }
      }
      page.drawPage(americanFlag, opts)
      i++
    }
    // Serialize the PDFDocument to bytes (a Uint8Array)
    const pdfBytes = await pdfDoc.save()
    fs.writeFileSync(path.join(folderPath, 'total.pdf'), pdfBytes)
  })()

以上,核心代码在github都有,直接拿过来稍微改动即可。 接下来,准备将这个小工具做成web服务,扔到我的小工具中...

转载请注明出处: https://chrunlee.cn/article/pdf-collapse-tool.html


感谢支持!

赞赏支持
提交评论
评论信息 (请文明评论)
暂无评论,快来快来写想法...
推荐
因为自己的记录笔记的应用是有道云,又想着把有道云跟自己的小网站联通起来,所以查找了有道云的,然后实现了nodejs版本的sdk.
thinkjs框架使用ueditor记录。
最近在折腾的时候又想写less了,但是换框架了,成了thinkjs,考虑到开发阶段一直编译编译less的情况..最终根据middleware的特点实现了一个超级简单的less中间件。
在日常开发中,经常会频繁的做一些重复性的操作,作为一名程序员,解放双手的时刻到了
想做微信/支付宝支付很久了..奈何需要的资质太多,只能慢慢申请,等待,审核..终于下来了。
从上面那篇文章过来的,这里分享下nodejs对文件夹以及子文件进行批量删除的实现。
目前了解的有两个模块可以实现二维码的模块,一个是node-qrcode ,这个算是比较大众的,不过环境比较复杂,所以...连看都没看;还有一个是小众的 qr-image ,这个比较简单,没有其他环境依赖,安装即可用,因为要实现一个简单的在线二维码生成,就先用这个试试水了
使用nodejs连接ftp,进行ftp的操作,包括列表、上传、下载以及速率等。