Skip to main content

A library for parsing Talk Quote Work Get-Paid (TQWGP) text-based compliant sales and accounting documents.

Project description

Talk Quote Work Get-Paid (aka TQWGP) proposal and invoice parser

Build Status PyPI version

Your text base sales and accounting toolkit, especially designed for freelancers, by freelancers

Installing

pip install tqwgp-parser

Usage

Parsing proposals

First, declare your quote data:

my_proposal = {
    "title": "Tesla Model 3 Configurator",
    "date": "29 novembre 2016",
    "place": "Philadelphie",
    "version": "v1",
    "sect": {
        "email": "bf@bf-printer.com",
        "logo": "tests/samples/tesla_logo.png",
        "name": "BF Printer \\& Co",
    },
    "legal": {
        "address": {
            "city": "Philadelphie",
            "line1": "E Thompson Saint",
            "zip": "19125",
        },
        "siret": "999999999 00099",
    },
    "author": {
        "civility": "M.",
        "mobile": "07.73.35.51.00",
        "name": "Benjamin Franklin",
        "role": "membre",
    },
    "client": {
        "contact": {
            "civility": "M.",
            "name": "Elon Musk",
            "role": "CEO",
            "sason": "son",
        },
        "legal": {
            "address": {
                "city": "Chambourcy",
                "line1": "103 Route de Mantes",
                "zip": "78240",
            },
            "siret": "524335262 00084",
        },
        "name": "Tesla",
    },
    "object": "The current proposal includes ...\n",
    "prestations": [
        {
            "description": "Files for describing the steps of product configuration, their prices, etc.",
            "price": 5000,
            "title": "Definition of configurations",
        }
    ],
}

Note: your can look at more complete and various samples in tests/samples.

You can then process this proposal data using tqwgp_parser.parse_quote:

import pprint
from tqwgp_parser import parse_quote

my_parsed_proposal = parse_quote(my_proposal)
pprint.pprint(my_parsed_proposal)

Pro-tip: the data can be declared in flat files, for eg. using Yaml or Json formats. It could also be loaded from a database: this is your choice!

Parsing invoices

Declare your invoices data:

my_invoices = {
    "sect": {"email": "bf@bf-printer.com", "name": "BF Printer \\& Co"},
    "legal": {
        "address": {
            "city": "Philadelphie",
            "line1": "E Thompson Saint",
            "zip": "19125",
        },
        "siret": "999999999 00099",
    },
    "author": {
        "civility": "M.",
        "mobile": "07.73.35.51.00",
        "name": "Benjamin Franklin",
        "role": "membre",
    },
    "client": {
        "contact": {
            "civility": "M.",
            "name": "Elon Musk",
            "role": "CEO",
            "sason": "son",
        },
        "legal": {
            "address": {
                "city": "Chambourcy",
                "line1": "103 Route de Mantes",
                "zip": "78240",
            },
            "siret": "524335262 00084",
        },
        "name": "Tesla",
    },
    "invoices": [
        {
            "date": "5 janvier 2017",
            "lines": [{"price": 12000, "title": "Acompte devis 16-TESLA-01"}],
            "number": "17001",
            "vat_rate": 20,
        }
    ],
}

And process it with the help of tqwgp_parser.parse_invoices:

import pprint
from tqwgp_parser import parse_invoices

my_parsed_invoices = parse_invoices(my_invoices)
pprint.pprint(my_parsed_invoices)

Going further

You could then feed the processed data to your own document edition toolchain to create PDFs from it. This could include using Pandoc and LaTeX to edit the PDF (see for eg. mrzool's invoice-boilerplate setup) ; or sending it to an online PDF compiler with your own template (for eg. with a LaTeX template and LaTeX-on-HTTP), or using HTML/CSS based template (with tooks like WeasyPrint or ReLaXed).

You may also use the parsed data in a web application.


TQWGP text-base documents specification

The format of the TQWGP text-base documents is not finalized.

We'll use this repository as a working specification, through the samples and tests.


Contributing

Tests

To contribute to the parser and specification, please wrote test samples for your modifications.

The tests are written for being runned with pytest:

pipenv run pytest -vv

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

tqwgp-parser-0.6.1.tar.gz (25.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

tqwgp_parser-0.6.1-py2.py3-none-any.whl (24.6 kB view details)

Uploaded Python 2Python 3

File details

Details for the file tqwgp-parser-0.6.1.tar.gz.

File metadata

  • Download URL: tqwgp-parser-0.6.1.tar.gz
  • Upload date:
  • Size: 25.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.0 CPython/3.10.10

File hashes

Hashes for tqwgp-parser-0.6.1.tar.gz
Algorithm Hash digest
SHA256 fb12fb1a8b142c729c2ea376b060f0a7fc6e926b0831a1bf4f4360a525217160
MD5 c84bf6df9fab877fa5699026fcd65806
BLAKE2b-256 a4cef34856013929b0b882bb48673f041c411b5941414f973a8b0327ed03dc07

See more details on using hashes here.

File details

Details for the file tqwgp_parser-0.6.1-py2.py3-none-any.whl.

File metadata

  • Download URL: tqwgp_parser-0.6.1-py2.py3-none-any.whl
  • Upload date:
  • Size: 24.6 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.0 CPython/3.10.10

File hashes

Hashes for tqwgp_parser-0.6.1-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 ea9f8c062790b6d1ac51cedf0403559c291787b7e67c78c3c844107c37cf83ce
MD5 e384bb9cc67b2c4d2c1ee15eb1852b45
BLAKE2b-256 893f45873b817dadfe7580ddd25e794c1ea0f528a73bd0f990f6741721d4e9eb

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page