No project description provided
Reason this release was yanked:
issue with not saving user
Project description
Overview
django-export-celery is a Django application that enables long processing exports using celery
and django-import-export
Dependencies
Python 3.6+
Packages
Django>=3.1
celery>=5.0.0
django-import-export>=2.2.0
Installation and Configuration
Celery must be setup before starting.
Please refer to Using Celery with Django for more information.
- Install with
pip
pip install django-export-celery
- Add apps to
INSTALLED_APPS
andMIDDLEWARE
to project settings.
# settings.py
INSTALLED_APPS = (
...
'import_export',
'django_export_celery',
)
# Optionally, sending emails is enabled by default on completed export
# Disable it by setting to False
DJANGO_EXPORT_CELERY_ENABLE_EMAIL = False
- Setup
model
andresources
# apps/models.py
from django.db import models
from import_export.resources import ModelResource
class Question(models.Model):
question_text = models.CharField(max_length=200)
pub_date = models.DateTimeField('date published')
@staticmethod
def get_export_resources():
return {
'rsc1': ('Question', QuestionResource),
}
class Choice(models.Model):
question = models.ForeignKey(Question, on_delete=models.CASCADE)
choice_text = models.CharField(max_length=200)
votes = models.IntegerField(default=0)
class QuestionResource(ModelResource):
class Meta:
model = Question
- Add
ExportCeleryMixin
to admin view inadmin.py
# apps/admin.py
from django.contrib import admin
from .models import Question, Choice
from import_export.admin import ImportExportMixin
from django_export_celery.mixins import ExportCeleryMixin
@admin.register(Question)
class QuestionAdmin(ExportCeleryMixin, admin.ModelAdmin):
list_display = (
'question_text',
'pub_date',
)
# also supports django-import-export admin mixins like so
@admin.register(Choice)
class ChoiceAdmin(ImportExportMixin, ExportCeleryMixin, admin.ModelAdmin):
list_display = (
'question',
'choice_text',
'votes',
)
How to use
- Click
EXPORT
button in upper right in model view
- Select export
Format
and clickSUBMIT
- Export jobs can be found in the
Export Jobs
app along with job status and file link
Demo App
./project/
contains the necessary files to start a sample project
To get started
cd project
pip install -r requirements.txt
python manage.py migrate
python manage.py createsuperuser
python manage.py runserver 8000
TODO: dummy data setup
TODO: Docker setup
Known Issues
A list of known issues to be patched in the future
- Does not respect ordering when exporting
- File format
ods
is not supported
Issue Tracker
If you have any bugs, suggestions, or compliants please report an issue here
References
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
Close
Hashes for django-export-celery-0.2.4.tar.gz
Algorithm | Hash digest | |
---|---|---|
SHA256 | f555fd99d07067e5e76adf34e209bb76936166d27b1c4906747be45f58f8b1ab |
|
MD5 | 098879fac591b6f9efff831ee60692ce |
|
BLAKE2b-256 | 6035b90d1adb8ba08099e0d945a1cd3525388ad9e039ed7b2c9c86b8e9ab0002 |
Close
Hashes for django_export_celery-0.2.4-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 4e039bca74f9d2b29cf0388092f8c6b0145a0db6749abeaa35100da3c700f7bc |
|
MD5 | ff187b208238439d38ad2cc8e3c37298 |
|
BLAKE2b-256 | 27fe121fcd0bcd57ae6b137691f9e69cd7eb13f54425e214cf11b23b232fd669 |