发票PDF在线合并小工具

发票PDF在线合并小工具

月光魔力鸭

2020-12-24 00:28 阅读 1572 喜欢 4 发票合并 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


感谢支持!

赞赏支持
提交评论
评论信息 (请文明评论)
暂无评论,快来快来写想法...
推荐
从豆瓣转到网易云后,发现了不少好听的歌曲,然鹅..当我想把这些歌拿下来扔车上听的时候发现竟然不允许下载..能听不能下?这不科学,作为一名程序猿,必然要迎难而上啊.
目前了解的有两个模块可以实现二维码的模块,一个是node-qrcode ,这个算是比较大众的,不过环境比较复杂,所以...连看都没看;还有一个是小众的 qr-image ,这个比较简单,没有其他环境依赖,安装即可用,因为要实现一个简单的在线二维码生成,就先用这个试试水了
使用nodejs连接ftp,进行ftp的操作,包括列表、上传、下载以及速率等。
前段时间做了个微信小程序反编译的小东西,不过因为功能不全,没加分包处理,正好处理下加上,又考虑到后续可能的更新情况,准备上手增加下更新功能。
因为自己的记录笔记的应用是有道云,又想着把有道云跟自己的小网站联通起来,所以查找了有道云的,然后实现了nodejs版本的sdk.
最近家里正在装修,实在是不知道怎么做,之前看好好住APP上有不少设计的图,部分还挺好看。。就去看了下有没有WEB端,结果还真有,就有了下文,我抓了几万张图片,然后根据关键字进行分类,从里面找心仪的设计。
前段时间帮朋友下歌放在车上听..结果好多都是ncm格式,伤心 ,搜索了下发现基本上这格式解密有好多昂,可惜UI我都不太想要..决定抄一下,自己做一个。 这里先记录下核心代码,回头补充个UI 做个小程序。
在我们做运维或者小工具的时候,总会有些需要提醒的事情,比如服务器宕机或者天气提醒,但是发email又会不够及时或者可能会忽略,那么短信就是一个不错的选择了