Django integration for Veryfi OCR API.
Project description
Django Veryfi OCR API Integration
As the title says, its a Django integration for Veryfi OCR API. For now, it can auto OCR receipts or invoices documents by using dj_veryfi.fields.OCRInvoiceOrReceiptField model field. It derives from django.db.models.JSONField model field and, takes a additional parameter upload_to which specifies the path where the file should be saved according to current defined Django STORAGE.
Requirements
Python 3 Django >= 3.2.20 Veryfi 3.3.0
How it works
Once you have defined a model field as dj_veryfi.fields.OCRInvoiceOrReceiptField, you can assign a file-like instance to an instance model field of dj_veryfi.fields.OCRInvoiceOrReceiptField, then, before saving the model, it gonna hit the Veryfi OCR API to extract information and persists it as JSON into datababse. When the field instance is acceesed after extraction it returns a OCRData instance which has the file descriptor and the JSON data.
How to install
pip install dj-veryfi
Setup
Add dj_veryfi into INSTALLED_APPS and set the Veryfi API authentication information into settings.py as described bellow:
...
INSTALLED_APS = [
...
"dj_veryfi"
]
...
# Veryfi access settings
VERYFI_CLIENT_ID = "Your client ID"
VERYFI_CLIENT_SECRET = "Your client secret"
VERYFI_USERNAME = "Your username"
VERYFI_API_KEY = "Your api key"
Usage
Once you have a django project, dj-veryfi installed and set up, just declare your model field as dj_veryfi.fields.OCRInvoiceOrReceiptField, as bellow.
from django.db import models
from dj_veryfi.fields import OCRInvoiceOrReceiptField
class Document(models.Model):
created_at = models.Datetime.FIeld(auto_now_add=True)
name = models.CharFied(max_length=100)
ocr_data = OCRInvoiceOrReceiptField(upload_to="receipts/")
Note, the upload_to attribute is a relative path which will append to MEDIA_ROOT settings variable.
Now, you can just assign a file-like object to Document.ocr_data save the model and, the information from receipt or invoice file will be extracted and saved as json into database.
Trade-Offs
I have chosen to extend the field from django.db.models.JSONField because the extracted data comes as JSON and I had to do nothing related to querying.
If I had chosen another model field type like FileField to get a shortcut to manage files and save them as JSON, I would have had trouble with how to query it into the database, due to JSON querying definition is not that simple.
So, it seems easier to me to avoid dealing with querying definitions when it comes to JSON querying, due to JSONField comes with "query thing" already done and deal with managing the files from where the information was extracted is easier.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
File details
Details for the file dj-veryfi-0.1.9.tar.gz
.
File metadata
- Download URL: dj-veryfi-0.1.9.tar.gz
- Upload date:
- Size: 4.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.7.10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 8181e33a07a860346a8572f608923fb32443ddb9651a8eac86cf01c86a55cd45 |
|
MD5 | 02d2c2b1dfb219abd9160d5a42190d31 |
|
BLAKE2b-256 | ab4691f9927250e6f805d764e144fa09d691a7d61cae16d2bc9887b348e77fbf |