我想使用 pypdf 创建/修改 pdf 文档的标题。似乎标题是只读的。有没有办法访问这个元数据 r/w?
如果回答是肯定的,将不胜感激一段代码。
谢谢
您可以使用 pyPDF 操作标题(有点)。我在 reportlab-users 列表中看到了这篇文章:
http://two.pairlist.net/pipermail/reportlab-users/2009-November/009033.html
您也可以使用 pypdf。 http://pybrary.net/pyPdf/
这不会让您编辑元数据本身,但会让您读取一个或多个 pdf 文件并将它们吐回,可能带有新的元数据。
以下是相关代码:
from pyPdf import PdfFileWriter, PdfFileReader
from pyPdf.generic import NameObject, createStringObject
OUTPUT = 'output.pdf'
INPUTS = ['test1.pdf', 'test2.pdf', 'test3.pdf']
# There is no interface through pyPDF with which to set this other then getting
# your hands dirty like so:
infoDict = output._info.getObject()
infoDict.update({
NameObject('/Title'): createStringObject(u'title'),
NameObject('/Author'): createStringObject(u'author'),
NameObject('/Subject'): createStringObject(u'subject'),
NameObject('/Creator'): createStringObject(u'a script')
})
inputs = [PdfFileReader(i) for i in INPUTS]
for input in inputs:
for page in range(input.getNumPages()):
output.addPage(input.getPage(page))
outputStream = file(OUTPUT, 'wb')
output.write(outputStream)
outputStream.close()