Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/python/277.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/django/21.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Python 无法创建Django ValueError对象,因为数据没有';无法验证_Python_Django - Fatal编程技术网

Python 无法创建Django ValueError对象,因为数据没有';无法验证

Python 无法创建Django ValueError对象,因为数据没有';无法验证,python,django,Python,Django,我正在尝试验证模型表单,但收到此错误由于数据未验证,无法创建成员。失败的行是employee=form.save(commit=False) 这是我的表格: class EmployeeForm(forms.ModelForm): class Meta: model = Member fields = ['first_name', 'last_name', 'customer_code', 'address1', 'address2', 'city', '

我正在尝试验证模型表单,但收到此错误
由于数据未验证,无法创建成员。
失败的行是
employee=form.save(commit=False)

这是我的表格:

class EmployeeForm(forms.ModelForm):
    class Meta:
        model = Member
        fields = ['first_name', 'last_name', 'customer_code', 'address1', 'address2', 'city', 'state', 'zip_code', 'telephone']

    def __init__(self, *args, **kwargs):
        super(EmployeeForm, self).__init__(*args, **kwargs)
        self.fields['first_name'].widget = TextInput(attrs={
            'placeholder': 'First Name'})
        self.fields['last_name'].widget = TextInput(attrs={
            'placeholder': 'Last Name'})
        self.fields['customer_code'].widget = TextInput(attrs={
            'placeholder': 'Customer Code'})
        self.fields['address1'].widget = TextInput(attrs={
            'placeholder': 'Address'})
        self.fields['address2'].widget = TextInput(attrs={
            'placeholder': 'Address Line 2'})
        self.fields['city'].widget = TextInput(attrs={
            'placeholder': 'City'})
        self.fields['state'].widget = TextInput(attrs={
            'placeholder': 'State'})
        self.fields['zip_code'].widget = TextInput(attrs={
            'placeholder': 'Zip Code'})
        self.fields['telephone'].widget = TextInput(attrs={
            'placeholder': 'Telephone'})

    def is_valid(self):
        #super(EmployeeForm, self).clean()
        if 'customer_code' in self.errors:
            del self._errors['customer_code']
        return self
以下是我的观点:

@login_required
def employee_register(request):
    if request.method == 'POST':
        form = EmployeeForm(request.POST)
        if form.is_valid():
            print "FORM IS VALID"
            employee = form.save(commit = False)
            code = employee.customer_code
            try:
                employer = Member.objects.get(customer_code = code)
                print "GOT EMPLOYER"
                employee.employer = employer
            except ObjectDoesNotExist:
                print "NO EMPLOYER FOUND"
                error = "The customer code entered does not match a valid customer in our database."
                return render_to_response('app/employee_register.html', {'form' : form, 'error' : error}, context_instance = RequestContext(request))
            employee.user = request.user
            employee.role = "Attendee"
            employee.customer_code = None
            employee.save()
            print "SAVED USER"

            return HttpResponseRedirect(reverse('app:mainRouter'))
        else:
            print "FORM NOT VALID"
            return render_to_response('app/employee_register.html', {'form' : form}, context_instance = RequestContext(request))
    else:
        form = EmployeeForm()
        return render_to_response('app/employee_register.html', {'form' : form}, context_instance = RequestContext(request))
我的模型是:

class Member(models.Model):
    first_name = models.CharField(max_length = 30)
    last_name = models.CharField(max_length = 30)
    user = models.OneToOneField(User, null = False)
    email = models.EmailField(null = False)
    address1 = models.CharField(max_length=100)
    address2 = models.CharField(max_length=100, blank=True, null = True)
    city = models.CharField(max_length=100)
    state = models.CharField(max_length=2)
    zip_code = models.CharField(max_length=5)
    country = models.CharField(max_length=50, null = True, blank = True)
    telephone = models.CharField(max_length = 15)


    role_choices = (
        ('Attendee', 'Attendee'),
        ('Customer', 'Customer'),
        ('Registrar', 'Registrar'),
        ('Area Coordinator', 'Area Coordinator'),
        ('Admin', 'Admin'),
        ('Sales', 'Sales'),

        )

    role = models.CharField(choices = role_choices, max_length = 50)
    employer = models.ForeignKey('Member', null = True, blank = True)
    ## ATTENDEE FIELDS

    #employer_code = models.CharField(max_length = 50, null = True)
    electrosign = models.BooleanField(default = False)

    ##CUSTOMER FIELDS
    customer_code = models.CharField(max_length = 50, null = True, unique = True, blank = True)
    insurance = models.ForeignKey('Insurance', null = True, blank = True)


    def __unicode__(self):
        name = self.first_name + self.last_name
        return name
我不确定问题可能是什么,在尝试保存对象之前,我正在检查表单
是否有效()。感谢所有帮助/建议。

您不能覆盖
是否有效

按照您的方式,您从
返回
self
是有效的,因为这不是无、假或空字符串或列表,所以它被认为是真的:因此您的表单始终是“有效的”

定制验证的正确方法是重写
clean
方法,这就是您在这里应该做的;
clean
的正确返回值为
self.cleaned\u data