имя_1,
компания_1 и
клиент_1
Наши данные для заполнения представлены как на иврите, так и на английском языке.
Наша цель — создать файл, который можно будет открыть с RTL как в браузере, так и в Acrobat Reader.
Наша цель — Встречается, когда мы вручную сохраняем экспортированный файл из следующего кода, но нам
не хотелось бы сохранять его вручную или, если нет другого варианта, сохранять его программно.
Код: Выделить всё
import pdfrw
INVOICE_TEMPLATE_PATH = 'example.pdf'
INVOICE_OUTPUT_PATH = 'output.pdf'
ANNOT_KEY = '/Annots'
ANNOT_FIELD_KEY = '/T'
ANNOT_VAL_KEY = '/V'
ANNOT_RECT_KEY = '/Rect'
SUBTYPE_KEY = '/Subtype'
WIDGET_SUBTYPE_KEY = '/Widget'
def write_fillable_pdf(input_pdf_path, output_pdf_path, data_dict):
template_pdf = pdfrw.PdfReader(input_pdf_path)
template_pdf.Root.AcroForm.update(pdfrw.PdfDict(NeedAppearances=pdfrw.PdfObject('true')))
annotations = template_pdf.pages[0][ANNOT_KEY]
for annotation in annotations:
if annotation[SUBTYPE_KEY] == WIDGET_SUBTYPE_KEY:
if annotation[ANNOT_FIELD_KEY]:
key = annotation[ANNOT_FIELD_KEY][1:-1]
if key in data_dict.keys():
annotation.update(
pdfrw.PdfDict(AP=data_dict[key], V='{}'.format(data_dict[key]), Ff=1)
)
pdfrw.PdfWriter().write(output_pdf_path, template_pdf)
data_dict = {
'name_1': 'עידו',
'company_1': 'IBM',
'client_1': 'אסם'
}
if __name__ == '__main__':
write_fillable_pdf(INVOICE_TEMPLATE_PATH, INVOICE_OUTPUT_PATH, data_dict)
Когда экспортированный файл открывается в Acrobat Reader, Acrobat Reader выполняет определенную работу. в файле. По этой причине при выходе программа спрашивает, хотим ли мы сохранить файл.
Эта операция для нас жизненно важна, но нам она нужна автоматически.
Что это за операция и как сделать это программно в нашем коде? до или после экспорта..
Подробнее здесь: https://stackoverflow.com/questions/713 ... bat-reader