Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/nigma/django-easy-pdf
PDF views, the easy way
https://github.com/nigma/django-easy-pdf
django pdf pdf-generation python
Last synced: 6 days ago
JSON representation
PDF views, the easy way
- Host: GitHub
- URL: https://github.com/nigma/django-easy-pdf
- Owner: nigma
- License: mit
- Created: 2014-01-23T18:42:19.000Z (about 11 years ago)
- Default Branch: master
- Last Pushed: 2022-01-16T23:16:03.000Z (about 3 years ago)
- Last Synced: 2025-01-13T05:02:00.747Z (13 days ago)
- Topics: django, pdf, pdf-generation, python
- Language: Python
- Size: 377 KB
- Stars: 364
- Watchers: 13
- Forks: 138
- Open Issues: 47
-
Metadata Files:
- Readme: README.rst
- Changelog: HISTORY.rst
- Contributing: CONTRIBUTING.rst
- License: LICENSE
Awesome Lists containing this project
- starred-awesome - django-easy-pdf - PDF views, the easy way (Python)
README
Django PDF rendering
====================Django PDF rendering, the easy way.
.. image:: https://circleci.com/gh/nigma/django-easy-pdf/tree/master.svg?style=svg
:target: https://circleci.com/gh/nigma/django-easy-pdf/tree/master
:alt: Build Status
.. image:: https://img.shields.io/pypi/v/django-easy-pdf.svg
:target: https://pypi.python.org/pypi/django-easy-pdf/
:alt: Latest Version
.. image:: https://img.shields.io/badge/wheel-yes-green.svg
:target: https://pypi.python.org/pypi/django-easy-pdf/
:alt: Wheel
.. image:: https://img.shields.io/pypi/l/django-easy-pdf.svg
:target: https://pypi.python.org/pypi/django-easy-pdf/
:alt: LicenseDeveloped at `en.ig.ma software shop `_.
Development Version
-------------------Note: A new PDF rendering backend using WeasyPrint for more accurate rendering is in development under the develop branch.
See https://github.com/nigma/django-easy-pdf/pull/34 for changes, testing and discussion.If you rely on the ``xhtml2pdf`` rendering backend and templates pin the package version to ``django-easy-pdf>=0.1.1<0.2.0``.
Overview
--------This app makes rendering PDF files in Django really easy.
It can be used to create invoices, bills and other documents
from simple HTML markup and CSS styles. You can even embed images
and use custom fonts.The library provides both Class-Based View that is almost a drop-in
replacement for Django's ``TemplateView`` as well as helper functions
to render PDFs in the backend outside the request scope
(i.e. using Celery workers).Quickstart
----------1. Include ``django-easy-pdf``, ``xhtml2pdf`` in your ``requirements.txt`` file.
If you are on Python 3 you need to install the latest version of Reportlab and the beta version of xhtml2pdf::$ pip install xhtml2pdf>=0.2b1
2. Add ``easy_pdf`` to ``INSTALLED_APPS``.
3. Create HTML template for PDF document and add a view that will render it:
.. code-block:: css+django
{% extends "easy_pdf/base.html" %}
{% block content %}
Hi there!
{% endblock %}.. code-block:: python
from easy_pdf.views import PDFTemplateView
class HelloPDFView(PDFTemplateView):
template_name = 'hello.html'4. You can also use a mixin to output PDF from Django generic views:
.. code-block:: python
class PDFUserDetailView(PDFTemplateResponseMixin, DetailView):
model = get_user_model()
template_name = 'user_detail.html'Documentation
-------------The full documentation is at `django-easy-pdf.readthedocs.io `_.
A live demo is at `easy-pdf.herokuapp.com `_.
You can run it locally after installing dependencies by running ``python demo.py``
script from the cloned repository or through Docker with ``make demo``.Dependencies
------------``django-easy-pdf`` depends on:
- ``django>=1.10``
- ``xhtml2pdf>=0.2b1``
- ``reportlab``License
-------``django-easy-pdf`` is released under the MIT license.
Other Resources
---------------- GitHub repository - https://github.com/nigma/django-easy-pdf
- PyPi Package site - https://pypi.python.org/pypi/django-easy-pdf
- Docs - https://django-easy-pdf.readthedocs.io/Commercial Support
------------------This app and many other help us build better software
and focus on delivering quality projects faster.
We would love to help you with your next project so get in touch
by dropping an email at [email protected].