import os from PyPDF2 import PdfFileReader, PdfFileMerger from pdfjinja import PdfJinja from werkzeug.utils import secure_filename def fusion_fichiers(chemin_merge_pdf, nom_merge_pdf, liste_de_pdf): """ Permet de fusionner un ensemble de pdf :param chemin_merge_pdf: chemin ou l'on souhaite fusioner l'ensemble des pdf :param nom_merge_pdf: nom que l'on souhaite donner au fichier pdf final :param liste_de_pdf: liste de pdf avec leur chemin inclu :return: """ merger = PdfFileMerger() for filename in liste_de_pdf: merger.append(PdfFileReader(os.path.join(filename), "rb")) merger.write(os.path.join(chemin_merge_pdf, nom_merge_pdf)) def get_pdf_from_directory(chemin_des_pdf): """ Permet de récuperer l'ensemble des pdf d'un chemin :param chemin_des_pdf: :return: """ return [f for f in os.listdir(chemin_des_pdf) if f.endswith("pdf")] def remplir_template(dirname_template, pdf_template, dirname_output_file, pdf_output, dictionnaire): """ Fonction qui permet de remplir un pdf template :param dirname_template: chemin du fichier de template :param pdf_template: nom du fichier de template :param dirname_output_file: chemin des pdf généré :param pdf_output: nom du fichier pdf à générer :param dictionnaire: dictionnaire contenant le nom des textfields des pdf ainsi que leurs valeurs :return: """ template_pdf_file = os.path.join(dirname_template, pdf_template) template_pdf = PdfJinja(template_pdf_file) rendered_pdf = template_pdf(dictionnaire) output_file = os.path.join(dirname_output_file, pdf_output) rendered_pdf.write(open(output_file, 'wb')) def allowed_file(filename): allowed_extensions = {'pdf'} return '.' in filename and \ filename.rsplit('.', 1)[1].lower() in allowed_extensions def upload_file(file_to_upload, upload_folder): """ televersement d'un fichier :param file_to_upload: :param upload_folder: :return: """ file_to_upload.save(os.path.join(upload_folder, secure_filename(file_to_upload.filename))) def delete_file(pdf_path): if os.path.exists(pdf_path): os.remove(pdf_path)