首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >CSV大容量导入管理中的Django完整性误差

CSV大容量导入管理中的Django完整性误差
EN

Stack Overflow用户
提问于 2016-10-10 05:14:10
回答 1查看 419关注 0票数 1

我试图在Django管理中实现CSV导入,并保存与CSV文件的行相对应的批量数据。我有一个模型Employee,它有一个OneToOneField到Django的Auth模型。我已经编写了一个接受csv文件的自定义表单。但是,当我调用super().save()方法时,会得到一个完整性错误。

我的模型课是:

代码语言:javascript
复制
class Employee(models.Model):
    user = models.OneToOneField(User, primary_key=True)
    company = models.ForeignKey(Companies)
    department = models.ForeignKey(Departments)
    mobile = models.CharField(max_length=16, default="0", blank=True)
    gender = models.CharField(max_length=1, default="m", choices=GENDERS)
    image = models.ImageField(upload_to=getImageUploadPath, null=True, blank=True)
    designation = models.CharField(max_length=64)
    is_hod = models.BooleanField(default=False)
    is_director = models.BooleanField(default=False)

这是我的管理课:

代码语言:javascript
复制
class EmployeeAdmin(admin.ModelAdmin):
    list_display = ('user', 'company', 'department', 'designation', 'is_hod', 'is_director')
    search_fields = ['user__email', 'user__first_name', 'user__last_name']
    form = EmployeeForm

这是我的表格课:

代码语言:javascript
复制
class EmployeeForm(forms.ModelForm):
    company = forms.ModelChoiceField(queryset=Companies.objects.all())
    file_to_import = forms.FileField()

    class Meta:
        model = Employee
        fields = ("company", "file_to_import")

    def save(self, commit=True, *args, **kwargs):
        try:
            company = self.cleaned_data['company']
            records = csv.reader(self.cleaned_data['file_to_import'])
            for line in records:
                # Get CSV Data.

                # Create new employee.
                employee = CreateEmployee(email, firstName, lastName, gender, '', company.id, dept[0].id, designation, 
                           isSuperuser, isHod, isDirector)
            super(EmployeeForm, self).save(*args, **kwargs)

        except Exception as e:
            traceback.print_exc()
            raise forms.ValidationError('Something went wrong.')

CreateEmployee方法定义为:

代码语言:javascript
复制
@transaction.atomic
def CreateEmployee(email='', firstName='', lastName='', gender='', mobile='',
    companyId='', departmentId='', designation='', isSuperuser=False, isHod=False, isDirector=False):
    try:
        user = User(
            username=email,
            email=email,
            first_name=firstName,
            last_name=lastName,
            is_superuser=isSuperuser,
            is_active=True)
        password = getPassword(firstName, lastName)
        user.set_password(password)
        user.save()

        company = Companies(id=companyId)
        dept = Departments(id=departmentId)

        employee = Employee(
            user=user,
            mobile=mobile,
            gender=gender,
            designation=designation,
            company=company,
            department=dept,
            is_hod=isHod,
            is_director=isDirector)
        employee.save()
        return employee
    except DatabaseError as e:
        raise e
    return None

我在表单的with块中得到一个异常,错误是:IntegrityError: (1048, "Column 'user_id' cannot be null")

在跟踪中,我可以看到异常是在super(EmployeeForm, self).save(*args, **kwargs)行中引发的。我假设超级方法试图保存一个实例。

完整的回溯是:

代码语言:javascript
复制
Traceback (most recent call last):
  File "/home/rachit/Projects/project/users/forms.py", line 81, in save
    super(EmployeeForm, self).save(*args, **kwargs)
  File "/usr/local/lib/python2.7/dist-packages/django/forms/models.py", line 455, in save
    construct=False)
  -- lot of text --
IntegrityError: (1048, "Column 'user_id' cannot be null")

我猜想ModelForm的save方法正在尝试保存一个实例,但我不希望这种情况发生,因为我已经创建了多个用户。

我在这里做错什么了?有没有其他方法来实现我想要的呢?

蒂娅。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-10-10 05:22:48

因为您正在进行自己的保存,所以不需要调用Super上的save。通常,当您需要像这样填写外键字段时,可以使用commit=False获取未保存模型的实例。但您可以这样做:

代码语言:javascript
复制
def save(self, commit=True, *args, **kwargs):
    try:
        company = self.cleaned_data['company']
        records = csv.reader(self.cleaned_data['file_to_import'])
        for line in records:
            # Get CSV Data.

            # Create new employee.
            employee = CreateEmployee(email, firstName, lastName, gender, '', company.id, dept[0].id, designation, 
                       isSuperuser, isHod, isDirector)
        # super(EmployeeForm, self).save(*args, **kwargs)
        # - or -
        super(EmployeeForm, self).save(commit=False)
        # updated based on additional comment
        return employee

    except Exception as e:
        traceback.print_exc()
        raise forms.ValidationError('Something went wrong.')
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/39951637

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档