Se rendre au contenu
Menu
Cette question a été signalée
2 Réponses
12443 Vues

The scenario is this,

I have a class with binary field,

file_to_import = fields.Binary('File')

file_to_import_fname = fields.Char('Filename')

The file to be submitted to this field is in predefine format and if of type PDF.

I have a button next to the binary field in view, Import. The related action uses tabula, parse through file and retrieve table contents in it and create records.

How do I pass the base64 encoded string to Tabula. The line to read PDF contents in tabula is,

df = tabula.read_pdf(file_to_import, output_format="json", pages="all")

Avatar
Ignorer
Auteur Meilleure réponse

I can read the contents of the file with this technique.

pdf_file = open('/tmp/pdffile.pdf','w')
pdf_file.write((base64.b64decode(obj.file_to_import)))
pdf_file.close()

df = tabula.read_pdf("/tmp/pdffile.pdf", output_format="json", pages="all")

Avatar
Ignorer
Meilleure réponse

That's a very good trick. I will try that on. Thanks.

Avatar
Ignorer
Publications associées Réponses Vues Activité
3
août 25
209
3
août 25
1567
1
juil. 25
602
0
août 25
499
1
juin 25
925