Data retrieval, template manager and delivery all in one!
Project description
Quipus, data retrieval, template manager and delivery all in one!
Documentation: TBD
Source Code: https://github.com/Monkey-Market/quipus
Quipus is a Python package that allows you to retrieve data from different sources, manage templates and deliver them in a single package. It is designed to be simple and easy to use, with a focus on performance and reliability.
Key features:
- Data retrieval: Retrieve data from different sources such as databases, APIs, and files.
- Template manager: Manage templates for different types of documents.
- Delivery: Deliver the generated documents to different destinations such as email, file system, cloud storage and more.
- Easy to use: Simple and easy to use package with a focus on developer experience.
Requirements & Dependencies
Quipus is empowered by the foundational work of industry giants. The following are the key dependencies:
- Pandas for data manipulation.
- WeasyPrint for document generation.
- Boto3 for AWS cloud storage.
Installation
You can install Quipus using pip
:
pip install quipus
Or with poetry
:
poetry add quipus
Usage Example
Import the package
import quipus as qp
Fetch data from CSV and generate PDFs
template_manager = (
qp.TemplateManager()
.from_csv("data/data_source.csv")
.with_template(qp.Template("templates/pdf_template.html"))
.decide_filename_with(lambda data: f"{data['name']}")
.to_pdf(output_path="output", create_dir=True)
)
Set up SMTP configuration
Note: These can be set up as environment variables for security reasons.
smtp_config = qp.SMTPConfig(
server="smtp.server.com",
port=587,
username="username",
password="password",
use_tls=True,
)
email_sender = qp.EmailSender(smtp_config)
Send emails with attachments
for item in template_manager.data:
smtp_message = (
qp.EmailMessageBuilder(
from_address="example@sender.com",
to_addresses=[item["email"], "another_email@example.com"]
)
.with_body_path("templates/email_body_template.html", "html", item)
.with_subject("Your email subject")
.add_attachment_from_path(f"output/{item['name']}.pdf")
.build()
)
email_sender.send(smtp_message)
This is a simple example of how you can use Quipus to fetch data from a CSV file, generate PDFs using a template, and send emails with the generated PDFs as attachments.
Contributing
Contributions are welcome! Please read our contributing guidelines for more information.
You can always open an issue or submit a pull request if you have any suggestions or improvements.
Contributors
Jorge U. Alarcón |
Fernando Nicolás |
Trivia
The name "Quipus" comes from the Quechua word "khipu" which refers to a method used by the Incas to keep records and communicate information through a system of knots and strings.
We thought it was a fitting name for a package that helps you manage and deliver data in a structured and organized way.
You can read more about it in this wikipedia page.
License
This project is licensed under the terms of the GNU General Public License v3.0.
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
Built Distribution
File details
Details for the file quipus-0.3.2.tar.gz
.
File metadata
- Download URL: quipus-0.3.2.tar.gz
- Upload date:
- Size: 38.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.4 CPython/3.12.7 Linux/6.5.0-1025-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | c5c510f17b3b0e6e5fd7da10a5532135b6214039854adc83bb1f1083afcc2acf |
|
MD5 | 2e03a36562be0244472c50453d0a59c1 |
|
BLAKE2b-256 | 5ddb4f49a2733edc7373ffdc80a4daed3b66e4868cfa7fbfaf8a7c9bf0249d44 |
File details
Details for the file quipus-0.3.2-py3-none-any.whl
.
File metadata
- Download URL: quipus-0.3.2-py3-none-any.whl
- Upload date:
- Size: 48.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.4 CPython/3.12.7 Linux/6.5.0-1025-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 1efe792b58f93b2da08a6b8889f8208434637cda79a87c1af1540e97205d3849 |
|
MD5 | e44d64b80cb7acc2fd73a34b7ef0c828 |
|
BLAKE2b-256 | 53aa760b0af0965a3af31f26b9254913840fc0b86cc96d7de85a94fa4fc36f67 |