j'utilise Django pour créer un utilisateur et un objet lors de la création de l'utilisateur. Mais il y a une erreur
__init__() got an unexpected keyword argument 'user'
lors de l'appel de la fonction register()
dans view.py. La fonction est:
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))
et la classe d'objet est:
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)
La page d'erreur Django notifie les informations d'erreur: user=User.objects.create_user(username, email, password)
et LivingRoom.objects.create(user=instance)
.
J'ai essayé de rechercher ce problème, en trouvant quelques cas, mais je ne peux toujours pas trouver comment le résoudre.
Tu ne peux pas faire
LivingRoom.objects.create(user=instance)
parce que vous avez une méthode init qui ne prend pas user
en argument.
Vous voulez quelque chose comme
#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
J'ai eu la même erreur.
De mon point de vue, je remplaçais get_form_kwargs () comme ceci:
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
Mais sur mon formulaire, j’ai omis de remplacer la méthode init (). Une fois je l'ai fait. Problème résolu
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)
LivingRoom.objects.create()
appelle LivingRoom.__init__()
- comme vous l'avez peut-être remarqué si vous aviez lu le traceback - lui transmettant les mêmes arguments. Pour faire une histoire courte, l'initialiseur d'une sous-classe Django models.Model
est préférable de le laisser seul, ou doit accepter * args et ** kwargs correspondant aux méta-champs du modèle. La manière correcte de fournir des valeurs par défaut pour les champs consiste à utiliser le constructeur de champs à l'aide du mot clé default
, comme expliqué dans le manuel FineManual.
Vérifiez vos importations. Il pourrait y avoir deux classes du même nom. Soit de votre code ou d'une bibliothèque que vous utilisez. Personnellement c'était le problème.