У меня есть проект, в котором мне нужно заполнить готовые PDF-файлы, и самое логичное решение, которое приходит на ум, чтобы сделать это, состоит в том, чтобы превратить готовые PDF-файлы в PDF-формы, чтобы были теги, в которых входные значения должныТеперь я могу просмотреть теги формы в PDF и выровнять их со словарем значений.
Я сделал это, используя PyPDF2 .В целом, я взял изображение веб-формы, а затем открыл Acrobat и создал форму PDF на основе полей, видимых на изображении, а затем использовал PyPDF2 для заполнения полей формы PDF, но предостережение заключается в том, чтопечать заполненных значений кажется некорректной в некоторых браузерах, в том числе и в Firefox.
Как я смог преобразовать мою PDF-форму в стандартный / плоский PDF, чтобы я мог сохранить предварительно заполненные значения, но потерять редактируемые поля (как мне кажется, в этом проблема)?
from io import BytesIO
import PyPDF2
from django.http import HttpResponse
from PyPDF2.generic import BooleanObject, NameObject, IndirectObject
def pdf_view(request):
template = 'templates/template.pdf'
outfile = "templates/test.pdf"
input_stream = open(template, "rb")
pdf_reader = PyPDF2.PdfFileReader(input_stream, strict=False)
if "/AcroForm" in pdf_reader.trailer["/Root"]:
pdf_reader.trailer["/Root"]["/AcroForm"].update(
{NameObject("/NeedAppearances"): BooleanObject(True)})
pdf_writer = PyPDF2.PdfFileWriter()
set_need_appearances_writer(pdf_writer)
if "/AcroForm" in pdf_writer._root_object:
# Acro form is form field, set needs appearances to fix printing issues
pdf_writer._root_object["/AcroForm"].update(
{NameObject("/NeedAppearances"): BooleanObject(True)})
data_dict = {
'first_name': 'John',
'last_name': 'Smith',
'email': 'mail@mail.com',
'phone': '889-998-9967',
'company': 'Amazing Inc.',
'job_title': 'Dev',
'street': '123 Main Way',
'city': 'Johannesburg',
'state': 'New Mexico',
'zip': 96705,
'country': 'USA',
'topic': 'Who cares...'
}
pdf_writer.addPage(pdf_reader.getPage(0))
pdf_writer.updatePageFormFieldValues(pdf_writer.getPage(0), data_dict)
output_stream = BytesIO()
pdf_writer.write(output_stream)
# print(fill_in_pdf(template, data_dict).getvalue())
# fill_in_pdf(template, data_dict).getvalue()
response = HttpResponse(output_stream.getvalue(), content_type='application/pdf')
response['Content-Disposition'] = 'inline; filename="completed.pdf"'
input_stream.close()
return response
def set_need_appearances_writer(writer):
try:
catalog = writer._root_object
# get the AcroForm tree and add "/NeedAppearances attribute
if "/AcroForm" not in catalog:
writer._root_object.update({
NameObject("/AcroForm"): IndirectObject(len(writer._objects), 0, writer)})
need_appearances = NameObject("/NeedAppearances")
writer._root_object["/AcroForm"][need_appearances] = BooleanObject(True)
except Exception as e:
print('set_need_appearances_writer() catch : ', repr(e))
return writer