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()
希望这能帮助任何有类似问题的人