2017-03-28 14:30:45 +02:00
|
|
|
import os
|
|
|
|
|
|
|
|
from PyPDF2 import PdfFileReader, PdfFileMerger
|
|
|
|
from pdfjinja import PdfJinja
|
2017-03-28 17:03:12 +02:00
|
|
|
from werkzeug.utils import secure_filename
|
2017-03-28 14:30:45 +02:00
|
|
|
|
|
|
|
|
|
|
|
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):
|
2017-03-28 17:03:12 +02:00
|
|
|
allowed_extensions = {'pdf'}
|
2017-03-28 14:30:45 +02:00
|
|
|
return '.' in filename and \
|
|
|
|
filename.rsplit('.', 1)[1].lower() in allowed_extensions
|
|
|
|
|
|
|
|
|
2017-03-28 18:04:57 +02:00
|
|
|
def upload_file(file_to_upload, upload_folder):
|
2017-03-28 17:03:12 +02:00
|
|
|
"""
|
2017-03-31 12:28:00 +02:00
|
|
|
televersement d'un fichier
|
|
|
|
:param file_to_upload:
|
2017-03-28 17:03:12 +02:00
|
|
|
:param upload_folder:
|
|
|
|
:return:
|
|
|
|
"""
|
2017-03-28 18:04:57 +02:00
|
|
|
file_to_upload.save(os.path.join(upload_folder, secure_filename(file_to_upload.filename)))
|
2017-03-28 17:03:12 +02:00
|
|
|
|
|
|
|
|
2017-03-28 10:10:22 +02:00
|
|
|
def delete_file(pdf_path):
|
|
|
|
if os.path.exists(pdf_path):
|
|
|
|
os.remove(pdf_path)
|