要向窗体和数据库django添加另一个字段吗

要向窗体和数据库django添加另一个字段吗,django,django-models,django-forms,django-views,django-database,Django,Django Models,Django Forms,Django Views,Django Database,我尝试在forms.py和models.py中添加另一个字段(pin) 我犯的错误是 “在/student/signup处出现字段错误/ 无法将关键字“pin”解析到字段中。选项包括:加入日期、电子邮件、名字、组、id、是否活动、是否工作人员、是否超级用户、上次登录、上次姓名、日志条目、密码、用户信息、用户权限、用户名” forms.py class RegisterForm(forms.Form): GRADE_CHOICES = ( (9,'9')

我尝试在forms.py和models.py中添加另一个字段(pin)

我犯的错误是

“在/student/signup处出现字段错误/ 无法将关键字“pin”解析到字段中。选项包括:加入日期、电子邮件、名字、组、id、是否活动、是否工作人员、是否超级用户、上次登录、上次姓名、日志条目、密码、用户信息、用户权限、用户名”

forms.py

 class RegisterForm(forms.Form):
    GRADE_CHOICES = ( 
                (9,'9'), (10,'10'), (11,'11'), (12,'12') , 
            )
    curr_year = date.today().year
    GRAD_YEAR_CHOICES = ( 
                (curr_year,curr_year), (curr_year+1,curr_year+1), (curr_year+2,curr_year+2), (curr_year+3,curr_year+3) , 
                 )
    first_name = forms.CharField(max_length = 25)
    last_name = forms.CharField( max_length = 25)
    emailid = forms.EmailField()
    passwd1 = forms.CharField(max_length=100,widget=forms.PasswordInput)
    passwd2 = forms.CharField(max_length=100,widget=forms.PasswordInput)
    gradyear = forms.ChoiceField( choices=GRAD_YEAR_CHOICES)
    grade = forms.ChoiceField( choices=GRADE_CHOICES)
    pin = forms.IntegerField()
    def clean(self):
        cleaned_data = super(RegisterForm, self).clean()
        print cleaned_data
        if cleaned_data['passwd1'] != cleaned_data['passwd2']:
            raise forms.ValidationError({'passwd1':['Password do not match']})

        if User.objects.filter(email=cleaned_data['emailid']).count():
            raise forms.ValidationError({'emailid':['Email already taken ']})
        if User.objects.filter(pin=cleaned_data['pin']).count():
            raise forms.ValidationError({'pin':['Pin already taken ']})

        return cleaned_data
views.py

 def signup(request):
        print "signup"
        if request.method == 'POST':
            print "post signup"
            form = RegisterForm(request.POST)
            try:
                if form.is_valid():
                    print form.cleaned_data
                    u = User.objects.create_user(form.cleaned_data['emailid'], form.cleaned_data['emailid'], form.cleaned_data['passwd1'] )
                    ui = UserInfo()
                    ui.user = u
                    ui.class_of = form.cleaned_data['gradyear']
                    ui.grade = form.cleaned_data['grade']
                    ui.balance = 0
                    print "Hi"
                    ui.pin = form.cleaned_data['pin']
                    print ui.pin
                    u.first_name = form.cleaned_data['first_name']
                    u.last_name = form.cleaned_data['last_name']
                    u.save()
                    ui.save()
                    user = authenticate(username=form.cleaned_data['emailid'], password=form.cleaned_data['passwd1'])
                    login(request,user)
                    print "after login in signup"
                    return redirect("/")


                else:
                    print "error"
                    print form.errors
            except:
                raise
                print "error here"
                print form.errors
                pass
                #return render(request, 'student/register.html', {'form': form})

        else:
            form = RegisterForm()

        return render(request, 'student/register.html', {'form': form})
models.py:

 class UserInfo(models.Model):
    user = models.OneToOneField(User, related_name='user_infos')
    class_of = models.IntegerField()
    #username = user.username
    #fname = user.fname
    #lname = user.last_name
    #email = user.email
    #Staff = user.is_staff
    pub_date = models.DateTimeField( auto_now=True)
    grade = models.IntegerField()
    balance = models.DecimalField(max_digits=6, decimal_places=2)
    pin = models.IntegerField()
    #first_name = models.CharField(max_length = 25)
我认为这样做是不对的。是否有其他方法在数据库中以其他方式添加另一列?

您的UserInfo模型中有“pin”字段,但在forms.py中,您试图筛选用户模型:

if User.objects.filter(pin=cleaned_data['pin']).count():
用户型号没有“pin”字段,因此您将收到该错误消息


另外,我建议您学习并开始使用ModelForms:

如果我尝试将其更改为UserInfo.objects,它会说UserInfo未定义,如果我尝试从模型导入UserInfo,它会说它无法导入UserInfo@AlexanderAllakhVerdiyev您应该能够导入用户信息:“从signup.models导入用户信息”。如果这不起作用,您可能还有一些其他问题。“ImportError位于/student/signup/无法导入name UserInfo”“ImportError位于/student/signup/没有名为signup.models的模块”