Import csv data into database in Django Admin

后端 未结 3 1594
粉色の甜心
粉色の甜心 2020-12-04 08:51

I\'ve tried to import a csv file into a database by tweaking the modelform inside the admin doing this:

models.py:

class Data(models.Model):
    plac         


        
3条回答
  •  醉酒成梦
    2020-12-04 09:25

    After a long search i found an answer: Create a view inside the admin using a standard form

    Form:

    class DataInput(forms.Form):
        file = forms.FileField()
        place = forms.ModelChoiceField(queryset=Place.objects.all())
    
        def save(self):
            records = csv.reader(self.cleaned_data["file"])
            for line in records:
                input_data = Data()
                input_data.place = self.cleaned_data["place"]
                input_data.time = datetime.strptime(line[1], "%m/%d/%y %H:%M:%S")
                input_data.data_1 = line[2]
                input_data.data_2 = line[3]
                input_data.data_3 = line[4]
                input_data.save()
    

    The view:

    @staff_member_required
    def import(request):
        if request.method == "POST":
            form = DataInput(request.POST, request.FILES)
            if form.is_valid():
                form.save()
                success = True
                context = {"form": form, "success": success}
                return render_to_response("imported.html", context,
                context_instance=RequestContext(request))
        else:
            form = DataInput()        
            context = {"form": form}
            return render_to_response("imported.html", context,
            context_instance=RequestContext(request)) 
    

    The rest is part of this post: http://web.archive.org/web/20100605043304/http://www.beardygeek.com/2010/03/adding-views-to-the-django-admin/

提交回复
热议问题