2013-11-14 6 views
10

Ich benutze Django, um einen Benutzer und ein Objekt zu erstellen, wenn der Benutzer erstellt wird. Aber es ist ein Fehler,__init __() hat ein unerwartetes Schlüsselwortargument 'user'

__init__() got an unexpected keyword argument 'user'

wenn die register() Funktion in view.py. Aufruf Die Funktion ist:

def register(request): 
    '''signup view'''  
    if request.method=="POST": 
     form=RegisterForm(request.POST) 
     if form.is_valid(): 
      username=form.cleaned_data["username"] 
      email=form.cleaned_data["email"] 
      password=form.cleaned_data["password"] 
      user=User.objects.create_user(username, email, password) 
      user.save() 
      return HttpResponseRedirect('/keenhome/accounts/login/') 
     else: 
      form = RegisterForm()  
      return render_to_response("polls/register.html", {'form':form}, context_instance=RequestContext(request)) 

    #This is used for reinputting if failed to register  
    else: 
     form = RegisterForm()  
     return render_to_response("polls/register.html", {'form':form}, context_instance=RequestContext(request)) 

und die Objektklasse ist:

class LivingRoom(models.Model): 
    '''Living Room object''' 
    user = models.OneToOneField(User) 

    def __init__(self, temp=65): 
     self.temp=temp 

    TURN_ON_OFF = (
     ('ON', 'On'), 
     ('OFF', 'Off'), 
    ) 

    TEMP = (
     ('HIGH', 'High'), 
     ('MEDIUM', 'Medium'), 
     ('LOW', 'Low'), 
    ) 

    on_off = models.CharField(max_length=2, choices=TURN_ON_OFF) 
    temp = models.CharField(max_length=2, choices=TEMP) 

#signal function: if a user is created, add control livingroom to the user  
def create_control_livingroom(sender, instance, created, **kwargs): 
    if created: 
     LivingRoom.objects.create(user=instance) 

post_save.connect(create_control_livingroom, sender=User) 

Die Django-Fehlerseite meldet die Fehlerinformationen: user=User.objects.create_user(username, email, password) und LivingRoom.objects.create(user=instance)

ich versucht, dieses Problem zu suchen , einige Fälle zu finden, aber immer noch nicht herausfinden, wie es zu lösen ist.

+0

Meine Vermutung ist, es ist hier versagt: 'create_control_livingroom' können Sie das Signal ausschalten und versuchen? und kannst du den stacktrace auch zeigen? – karthikr

+0

Warum schränken Sie die 'LivingRoom .__ init__' Methode auf * nur *' temp' ein? –

Antwort

5

können Sie nicht

LivingRoom.objects.create(user=instance) 

, weil Sie ein Init-Methode haben, die nicht user als Argument nimmt.

Sie wollen so etwas wie

#signal function: if a user is created, add control livingroom to the user  
def create_control_livingroom(sender, instance, created, **kwargs): 
    if created: 
     my_room = LivingRoom() 
     my_room.user = instance 
+0

Ja, das Problem ist von der '__init __()' Funktion, aber warum diese Funktion 'nimmt Benutzer nicht als Argument'? – noben

+0

Weil die Funktion "init" nur zwei akzeptable Variablen hat: def __init __ (self, temp = 65), self (Klasseninstanz) und temp. Auch die Klassenvariable "user" ist für diese Instanz noch nicht definiert. –

1

LivingRoom.objects.create() Anrufe LivingRoom.__init__() - wie Sie vielleicht bemerkt haben, wenn Sie die Rückverfolgung gelesen hatte - es sind die gleichen Argumente. Um es kurz zu machen: Der Initialisierer einer Django-models.Model -Insel wird am besten allein gelassen oder sollte * args und ** kwargs akzeptieren, die mit den Meta-Feldern des Modells übereinstimmen. Die richtige Methode zum Bereitstellen von Standardwerten für Felder ist im Feldkonstruktor mit dem Schlüsselwort default, wie im FineManual erklärt.

4

Ich habe den gleichen Fehler.

Auf meiner Sicht war ich zwingende get_form_kwargs() wie folgt aus:

class UserAccountView(FormView): 
    form_class = UserAccountForm 
    success_url = '/' 
    template_name = 'user_account/user-account.html' 

def get_form_kwargs(self): 
    kwargs = super(UserAccountView, self).get_form_kwargs() 
    kwargs.update({'user': self.request.user}) 
    return kwargs 

Aber auf meiner Form Ich verließ den init() -Methode außer Kraft zu setzen. Sobald ich es getan habe. Problem gelöst

class UserAccountForm(forms.Form): 
    first_name = forms.CharField(label='Your first name', max_length=30) 
    last_name = forms.CharField(label='Your last name', max_length=30) 
    email = forms.EmailField(max_length=75) 

    def __init__(self, *args, **kwargs): 
     user = kwargs.pop('user') 
     super(UserAccountForm, self).__init__(*args, **kwargs) 
+0

Der '** kwargs' und' super() 'Teil hat den Trick für mich gemacht – n1000

Verwandte Themen