Django - вставка данных из загруженного файла Excel в модель базы данных - PullRequest
0 голосов
/ 16 марта 2020

Я пытаюсь заполнить базу данных данными из загруженного файла xlsx.

Я выполнил шаги из этого урока: https://buildmedia.readthedocs.org/media/pdf/django-excel/latest/django-excel.pdf

В моем случае после загрузки появляется страница ошибки 404, в то время как файл журнала ошибок веб-сервера показывает только:

[Sun Mar 15 20:31:11.075408 2020] [wsgi:error] [pid 6756] [remote 192.168.1.7:53883] Bad Request: /Project/store/

Я как-то застрял в этой точке ... Я понимаю, что форма w недействительно, но почему?

извлечение из models.py

class Store(models.Model):
    code = models.CharField(max_length=100, unique=True)
    name = models.TextField()
    address = models.TextField()
    city = models.CharField(max_length=100)
    zip = models.IntegerField()
    def __str__(self):
        return self.cod+" "+self.nume
    class Meta:
        ordering = ["cod"]
        verbose_name_plural = "Stores"

извлечение из view.py

class UploadFileForm(forms.Form):
    file = forms.FileField()

def store(request):
    if request.method == "POST":
        form = UploadFileForm(request.POST, request.FILES)
        if form.is_valid():
            request.FILES['file'].save_to_database(
                model=Store,
                mapdict=['code', 'name', 'address', 'city', 'zip'])
            return HttpResponse("OK")
        else:
            return HttpResponseBadRequest()
    else:
        return render(request, 'store.html', {})

извлечение из шаблона - хранилище. html

<form action="{% url "store" %}" method="post" enctype="multipart/form-data">
    {% csrf_token %}
    <div class="form-group mb-4 mt-3">
        <label for="exampleFormControlFile1">Excel file ONLY !</label>
        <input type="file" title="Upload excel file" name="excel_file"
 class="form-control-file" id="exampleFormControlFile1" required="required">
    </div>
    <input type="submit" value="Upload" name="time" class="mt-4 mb-4 btn btn-primary">
</form>

Данные файла xlsx

code    | name      | address           | city      | zip
    1   | Store01   | 191-st, Main street       | Calhounn  | 7000
    2   | Store02   | 277-th, River streetGaleria   | Verdounne | 9000

1 Ответ

0 голосов
/ 16 марта 2020

Вы должны использовать «файл» в качестве имени элемента ввода в html.

...