Появилась очень удобная система для импорта данных из excel в django:
Чтобы начать использовать это приложение django в своем проекте:
1. Переходим на страницу https://github.com/satels/django-import-excel и нажимаем кнопку Watch
2.Скачиваем проект себе https://github.com/satels/django-import-excel/zipball/master
3. Распаковываем, переходим в папку и запускаем pip install -e . или же python setup.py install
4. В settings.py:
INSTALLED_APPS = [
...
'import_excel',
...
]
5. Итак, например, нам надо импортировать данные из excel для модели
class Book(models.Model):
name = models.CharField(max_length=255)
author = models.CharField(max_length=255)
Файл excel же содержит данные
name | author
Мастер и Маргарита | Михаил Булгаков
И дольше века длится день | Чингиз Айтматов
Для этого создаем форму
from django.db import transaction
from import_excel.forms import ImportExcelForm
class BookImportForm(ImportExcelForm):
@transaction.autocommit
def update_callback(self, request, converted_data):
for book_item in converted_data[1:]:
name = book_item[0]
author = book_item[1]
Book.objects.create(name=name, author=author)
Далее, в urls.py:
urlpatterns = patterns('',
url(r'^/books/import-from-excel/$', permission_required('books.add_book')(import_excel), {
'FormClass': BookImportForm, 'next_url': '/books/', 'with_good': True, 'template_name': 'import_excel/import_excel.html',
}, name='book-import-excel'),
),
Видим здесь мы указываем форму для загрузки книг, next_url - страницу для перехода после успешной загрузки, with_good - это значит, что надо подтвердить загружаемые данные с предварительным просмотром, также вы можете указывать template_name, если захотите задать свой (скопируйте файл из import_excel/templates/import_excel/import_excel.html)
Кстати pip умеет ставить zip файлы по url:
ОтветитьУдалитьpip install https://github.com/ostrovok-team/django-import-excel/zipball/master
Да, это чтобы побольше ключевых слов было на странице:)
ОтветитьУдалитьurlpatterns = patterns('',
ОтветитьУдалитьurl(r'^/books/import-from-excel/$', permission_required('books.add_book')(import_excel), {
'FormClass': BookImportForm, 'next_url': '/books/', 'with_good': True, 'template_name': 'import_excel/import_excel.html',
}, name='book-import-excel'),
),
Строчка непонятна: books.add_book - где описание этого метода? что в нем должно быть?
Еще для использования в urls.py должны быть подключены:
import import_excel
from django.contrib.auth.decorators import permission_required
На самом деле books.add_book - это права, которые должны быть, если модель books.Book и она подключена в admin.py.
ОтветитьУдалитьНа самом деле, вы можете сами задавать права https://docs.djangoproject.com/en/dev/topics/auth/#django.contrib.auth.models.User.has_perms