pdf merge online 線上pdf合併上線啦
做這個網站的起源是之前在開一個網路課程,每節課都有一個pdf課件。想合併成一個看起來方便些, 於是網上找一些線上的合併pdf工具,沒有特別好用的,只好自己擼一個
戳這裡試用pdfmerge.online/
剛開始用python做了一個,網上很多python合併pdf的例子,整理後下面這個可用
# -*- coding:utf-8*-
import sys
reload(sys)
sys.setdefaultencoding('utf-8')
import fnmatch
import os
import os.path
from pyPdf import PdfFileReader,PdfFileWriter
import time
time1=time.time()
# 使用os模組walk函式,搜尋出某目錄下的全部pdf檔案
######################獲取同一個資料夾下的所有PDF檔名#######################
def getFileName(filepath):
file_list = []
for n in range(1,10):
file_list.append(str(n)+'.pdf')
return file_list
##########################合併同一個資料夾下所有PDF檔案########################
def MergePDF(filepath,outfile):
output=PdfFileWriter()
outputPages=0
pdf_fileName=getFileName(filepath)
print pdf_fileName
for each in pdf_fileName:
# 讀取源pdf檔案
input = PdfFileReader(file('/root/test/pdf/'+each, "rb"))
# 如果pdf檔案已經加密,必須首先解密才能使用pyPdf
if input.isEncrypted == True:
input.decrypt("map")
# 獲得源pdf檔案中頁面總數
pageCount = input.getNumPages()
outputPages += pageCount
print pageCount
# 分別將page新增到輸出output中
for iPage in range(0, pageCount):
output.addPage(input.getPage(iPage))
print "All Pages Number:"+str(outputPages)
# 最後寫pdf檔案
outputStream=file(filepath+outfile,"wb")
output.write(outputStream)
outputStream.close()
print "finished"
if __name__ == '__main__':
file_dir = r'/root/test/pdf/'
out=u"out.pdf"
MergePDF(file_dir,out)
time2 = time.time()
print u'總共耗時:' + str(time2 - time1) + 's'
複製程式碼
但是我想要的是一個線上的pdf合併工具,所以用spring boot搭建了一個,既然用了java,就不用python做pdf合併了。 java方面itext對pdf的操作支援很豐富,自然少不了合併pdf,下面是合併pdf的核心程式碼
public class PdfService {
public static void main(String[] args) {
Map<Integer,String> files = new HashMap();
files.put(0,"e:\\1.pdf");
files.put(1, "e:\\2.pdf");
files.put(2, "e:\\3.pdf" );
String savepath = "e:\\temp.pdf";
new PdfService().mergePdfFiles(files, savepath);
}
public boolean mergePdfFiles(Map<Integer,String> files, String newfile) {
boolean retValue = false;
Document document = null;
try {
document = new Document(new PdfReader(files.get(0)).getPageSize(1));
PdfCopy copy = new PdfCopy(document, new FileOutputStream(newfile));
document.open();
for (int i = 0; i < files.size(); i++) {
PdfReader reader = new PdfReader(files.get(i));
int n = reader.getNumberOfPages();
for (int j = 1; j <= n; j++) {
document.newPage();
PdfImportedPage page = copy.getImportedPage(reader, j);
copy.addPage(page);
}
}
retValue = true;
} catch (Exception e) {
e.printStackTrace();
} finally {
document.close();
}
return retValue;
}
}
複製程式碼