为什么Django post_save信号给我pre_save数据?

时间:2009-08-03 11:42:42

标签: python django django-signals

我试图将“信息”对象连接到许多“客户”(参见下面的代码)

当更新一个信息对象时,我想向连接到信息的每个客户发送电子邮件。

然而,当我记录信号收到的sold_to字段时,我总是得到保存之前的数据。

我猜这是因为它的ManyToManyField和数据存储在一个单独的表中,但是在更新所有关系之后不应该调用post_save信号吗?

任何人都有解决方案的建议吗?

class Customer
    name = models.CharField(max_length=200)
    category = models.ManyToManyField('Category',symmetrical=False)
    contact = models.EmailField()

class Information
    name = models.CharField(max_length=200)
    email = models.EmailField(max_length=200)
    mod_date = models.DateTimeField(auto_now=True)
    sold_to = models.ManyToManyField(Customer, null=True, blank=True)


def send_admin_email(sender, instance, signal, *args, **kwargs):
    from myapp import settings
    for cust in instance.sold_to.all():
        settings.debug(cust.name)

post_save.connect(send_admin_email, sender=Information)

编辑:#django中的apollo13提醒我: “相关项目(保存为多对多关系的东西) 正如您所发现的那样,它们不会保存为模型的保存方法的一部分。“ - http://groups.google.com/group/django-users/msg/2b734c153537f970

但自2006年7月9日起,我真的希望有一个解决方案。

3 个答案:

答案 0 :(得分:5)

您面临的问题是here。您可以关注它何时进入发行版,或者您可以尝试应用它提供的补丁,看看是否有帮助。

答案 1 :(得分:1)

这是我的解决方案,应用了上面提到的code.djangoproject.com中的补丁。

在models.py中添加了这个:

from django.db.models.signals import m2m_changed
m2m_changed.connect(send_admin_email, sender=Information)

send_admin_email函数:

def send_customer_email(sender, instance, action, model, field_name, reverse, objects, **kwargs):
    if ("add" == action):
        # do stuff

答案 2 :(得分:1)

我遇到了同样的问题,因为我的模型中有M2M字段,我也得到了pre_save之类的数据。

在这种情况下,问题是在M2M字段中应保存两个相关模型以获取自动生成的ID。

在我的解决方案中,我既没有使用post_save信号也没有使用m2m_changed信号,而是使用了ModelAdmin类定义中的log_addition和log_change方法。

在自定义的ModelAdmin类中:

    class CustomModelAdmin(admin.ModelAdmin):
         def log_addition(self, request, object):
         """
         Log that an object has been successfully added.
         """
             super(CustomModelAdmin, self).log_addition(request, object)
             #call post_save callback here object created

         def log_change(self, request, object):
         """
         Log that an object has been successfully changed.
         """
             super(CustomModelAdmin, self).log_change(request, object)
             #call post_save callback here object changed

如果需要,您也可以覆盖log_deletion()方法。

快乐的压倒......