Django: Форма не сохраняется и возникает ошибка "Соответствующий запрос не существует"
Я пытаюсь создать приложение для импорта данных из загруженного .csv файла в мою базу данных. Вот мой код, и когда я пытаюсь отправить новый файл, форма не сохраняется в базе данных, и я перенаправляюсь на главную страницу. Я также не могу получить доступ к файлу, если я создаю его в администраторе, потому что я получаю эту ошибку Dataset matching query does not exist.
Я думаю, что моя проблема в ForeignKey и OneToOneField, которые я не могу сохранить должным образом? Только модель File составляется пользователем, в то время как Dataset должен быть заполнен из информации в файле и связан с файлом и пользователем автоматически. Спасибо всем за помощь!
ПРОСМОТРОВ
@login_required
def file_upload(request):
data = None
if request.method == 'POST':
file_form = FileForm(request.POST, request.FILES)
data_form = DatasetForm(request.POST, request.FILES)
raw_file= request.FILES
if file_form.is_valid() and data_form.is_valid():
data = request.FILES['file_upload']
data = pd.read_csv(data, header=0, encoding="UTF-8")
data_form.instance.user = request.user.profile
file_form.instance.user = request.user.profile
file_form.instance.filename = raw_file['file_upload'].name
Dataset.objects.create(
name_user_A = data.iloc[0,1],
name_user_B = data.iloc[1,1],
[...]
)
data_form.save()
file_form.save()
return redirect('upload_file')
else:
return redirect('home')
else:
form = FileForm()
context = {
'data': data,
'second_row': second_row,
'file_form': file_form,
'message': message,
}
return render(request, 'upload_file.html', context)
Вот как выглядят мои модели и формы:
МОДЕЛЬ
class File(models.Model):
user = models.ForeignKey(Profile, on_delete=models.CASCADE)
filename = models.CharField(max_length=250)
file_upload = models.FileField(upload_to=path)
upload_date = models.DateField(default=datetime.now)
def __str__(self):
return self.user.name + 'file'
class Dataset(models.Model):
user = models.ForeignKey(Profile, on_delete=models.CASCADE)
file_uploaded = models.OneToOneField(File, on_delete=models.CASCADE)
name_user_A = models.CharField(max_length=250)
code_user_A = models.PositiveIntegerField(null=True)
total_user_A = models.PositiveIntegerField(null=True)
sd_user_A = models.PositiveIntegerField(null=True)
name_user_B = models.CharField(max_length=250)
code_user_B = models.PositiveIntegerField(null=True)
total_user_B = models.PositiveIntegerField(null=True)
sd_user_B = models.PositiveIntegerField(null=True)
ФОРМЫ
class FileForm(forms.ModelForm):
class Meta:
model = File
fields = '__all__'
class DatasetForm(forms.ModelForm):
class Meta:
model = Dataset
fields = '__all__'