pdf merge online
在線pdf合并上線啦
做這個網(wǎng)站的起源是之前在開一個網(wǎng)絡(luò)課程拨匆,每節(jié)課都有一個pdf課件躬存。想合并成一個看起來方便些述寡,
于是網(wǎng)上找一些在線的合并pdf工具困介,沒有特別好用的姐刁,只好自己擼一個 戳這里試用https://pdfmerge.online/
剛開始用python做了一個天吓,網(wǎng)上很多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函數(shù),搜索出某目錄下的全部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文件已經(jīng)加密龄寞,必須首先解密才能使用pyPdf
if input.isEncrypted == True:
input.decrypt("map")
# 獲得源pdf文件中頁面總數(shù)
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;
}
}