2013-11-14 21 views
10

Używam Django do tworzenia użytkownika i obiektu podczas tworzenia użytkownika. Ale nie jest to błąd__init __() otrzymała nieoczekiwany argument słowa kluczowego "użytkownik"

__init__() got an unexpected keyword argument 'user'

podczas wywoływania funkcji w view.py. register() Funkcja:

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)) 

a klasa przedmiotem jest:

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) 

stronę błędu Django powiadamia informację o błędzie: user=User.objects.create_user(username, email, password) i LivingRoom.objects.create(user=instance)

Próbowałem szukać tego problemu , znajdowanie niektórych przypadków, ale wciąż nie może wymyślić, jak go rozwiązać.

+0

Zgaduję, że tutaj nie działa: 'create_control_livingroom' możesz wyłączyć sygnał i spróbować? i czy możesz pokazać także stacktrace? – karthikr

+0

Dlaczego ograniczasz metodę "LivingRoom .__ init__" do * just * 'temp', a następnie? –

Odpowiedz

5

Nie można zrobić

LivingRoom.objects.create(user=instance) 

bo masz metodę init, że nie bierze user jako argument.

Chcesz coś podobnego

#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

Tak, problem jest z funkcji '__init __()', ale dlaczego ta funkcja 'nie przyjmuje użytkownika jako argument'? – noben

+0

Ponieważ funkcja "init" ma tylko dwie dopuszczalne zmienne: 'def __init __ (self, temp = 65)', 'self' (instancja klasy) i' temp'. Również zmienna klasy "user" nie jest jeszcze zdefiniowana dla tej instancji. –

1

LivingRoom.objects.create() połączeń LivingRoom.__init__() - jak można zauważyć, jeśli czytał traceback - przepuszczenie go te same argumenty. Krótko mówiąc, inicjator podklasy Django models.Model najlepiej pozostawić samemu sobie lub przyjąć * args i ** kwargs pasujące do pól meta modelu. Prawidłowy sposób dostarczenia wartości domyślnych dla pól jest w konstruktorze pola przy użyciu słowa kluczowego default, jak wyjaśniono w FineManual.

4

Wystąpił ten sam błąd.

Na moim zdaniem ja nadrzędnymi get_form_kwargs() tak:

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 

Ale na mojej postaci nie udało mi się zastąpić metodę startowych(). Raz to zrobiłem. Problem rozwiązany

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

Część '** kwargs' i' super() 'zrobiła dla mnie sztuczkę – n1000