¿Por qué la señal post_save de Django me da datos de pre_save?

Estoy tratando de conectar un objeto “Información” a muchos “Clientes” (vea el código a continuación)

Cuando se actualiza un objeto de información, deseo enviar un correo electrónico a cada cliente que esté conectado a la información.

Sin embargo, cuando registro el campo sold_to que recibe la señal, siempre obtengo la información ANTES de guardar.

Supongo que esto se debe a que ManyToManyField y los datos se almacenan en una tabla separada, pero ¿no debería llamarse la señal post_save después de que se hayan actualizado todas las relaciones?

¿Alguien tiene una sugerencia para una solución?

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) 

Edición: apollo13 en #django me alertó de esto: “Los elementos relacionados (las cosas que se guardan en la relación de muchos a muchos) no se guardan como parte del método de guardado de un modelo, como ha descubierto.” – http://groups.google.com/group/django-users/msg/2b734c153537f970

Pero como es del 9 de julio de 2006, realmente espero que haya una solución para esto.

Hay un ticket abierto para el problema al que te enfrentas aquí . Puede vigilar eso para cuando se convierta en una versión, o puede intentar aplicar el parche que proporciona y ver si eso ayuda.

Esta es mi solución, después de aplicar el parche de code.djangoproject.com mencionado anteriormente.

Agregado esto en modelos.py:

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

Y la función send_admin_email:

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

Me encuentro con el mismo problema, ya que tengo campos M2M en mi modelo. También obtuve los datos similares a pre_save.

En la situación, el problema es que en los campos M2M, ambos modelos relacionados deben guardarse para obtener las ID generadas automáticamente.

En mi solución, ni usé la señal post_save ni la señal m2m_changed, en lugar de esas señales usé los métodos log_addition y log_change en la definición de clase ModelAdmin.

En su clase personalizada 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 

Si lo desea, también puede anular el método log_deletion ().

Feliz anulando …