Предварительное сохранение Django срабатывает дважды

#python #django #django-signals

#python #django #django-сигналы

Вопрос:

Я использую сигналы django для денормализации данных. Вот мой код:

 # vote was saved
@receiver(pre_save, sender=Vote)
def update_post_votes_on_save(sender, instance, **kwargs):
    """ Update post rating """
    # is vote is being updated, then we must remove previous value first
    if instance.id:
        old_vote = Vote.objects.get(pk=instance.id)
        instance.post.rating -= old_vote.value
    # now adding the new vote
    instance.post.rating  = instance.value
    instance.post.save()
  

Я не могу понять почему, но когда мой Vote экземпляр сохраняется, update_post_votes_on_save() вызывается дважды. Я думал, что в моем коде была ошибка, но сохранение через интерфейс администратора дает тот же результат.

В документах что-то говорится об использовании dispatch_uid для предотвращения повторяющихся вызовов, но я не могу понять, так ли это. Как использовать dispatch_uid ? Я пробовал это, но безуспешно:

 @receiver(pre_save, sender=Vote, dispatch_uid="my_unique_identifier")
  

Есть идеи, почему функция вызывается дважды и как этого избежать?

Комментарии:

1. Найдите в своей кодовой базе, где вы регистрируете сигнал — убедитесь, что он не зарегистрирован дважды

2. @chris: dispatch_uid должен предотвращать его регистрацию дважды. @silver-light: Как вы убедились, что ваш обработчик вызывается дважды?

3. Проверьте это groups.google.com/group/django-users/browse_thread/thread/… Возможно, у вас тоже дублируется регистрация.

4. @shadfc, да, я это сделал, используя отладчик в PyCharm

Ответ №1:

Прошу прощения за путаницу, но dispatch_uid в конце концов, проблема решена. Просто помните, что вам, возможно, придется перезапустить сервер разработки, чтобы увидеть эффект, прежде чем задавать вопрос по SO 🙂