Django models django后期保存方法导致身份验证错误
嗨,我有一个保存后信号,当创建新的用户对象时,它会保存一个用户配置文件对象:Django models django后期保存方法导致身份验证错误,django-models,Django Models,嗨,我有一个保存后信号,当创建新的用户对象时,它会保存一个用户配置文件对象: from django.db import models from django.contrib.auth.models import User from django.db.models.signals import post_save class UserProfile(models.Model): user = models.OneToOneField(User) ... def __
from django.db import models
from django.contrib.auth.models import User
from django.db.models.signals import post_save
class UserProfile(models.Model):
user = models.OneToOneField(User)
...
def __unicode__(self):
return self.user.username
def _create_user_profile(sender, instance, created, **kwargs):
UserProfile.objects.create(user=instance)
post_save.connect(_create_user_profile, sender=User)
但是,这给我带来了以下问题:
如果我在管理员中创建一个新用户,一切都很好。如果我随后尝试编辑,然后将用户
权限更改为员工状态,我将得到一个键“User\u id”的重复条目“6”
错误。我猜UserProfile
对象正在尝试重新保存该对象
我如何避免这种冲突
非常感谢您的帮助。好的,所以这帮了大忙: 基本上,我需要直接使用xpath查找
和
。之后,我可以模拟一个点击事件:
self.browser.find_element_by_xpath(
"//select[@id='my_select_id']/option[text()='my_option_text']"
).click()
如果文本字符串未知,我也可以选择“按选项索引”:
self.browser.find_element_by_xpath(
"//select[@id='id_module']/option[2]"
).click()
希望这能帮助任何有类似问题的人