使用Django的post_save()信号
我有两个表:
class Advertisement(models.Model):
created_at = models.DateTimeField(auto_now_add=True)
author_email = models.EmailField()
class Verification(models.Model):
advertisement = models.ForeignKeyField(Advertisement)
key = models.CharField(max_length=32)
我需要在添加新广告后,自动填充验证表。
def gen_key(sender, instance, created, **kwargs):
if created:
from hashlib import md5
vkey = md5("%s%s" % (instance.author_email, instance.created_at))
ver = Verification(advertisement=instance)
ver.key = vkey
ver.save()
post_save.connect(gen_key, sender=Advertisement)
当然,这样做是行不通的。使用的是Django 1.2版本。
问:我该怎么做呢?
好吧,问题部分解决了。
问题在于,父模型的post_save()方法没有调用子模型的post_save()。
所以你可以通过直接提供子类来解决这个问题。
class Advertisement(models.Model):
created_at = models.DateTimeField(auto_now_add=True)
author_email = models.EmailField()
class Sale(Advertisement):
rooms = models.IntegerField(max_length=1)
subway = models.ForeignKey(Subway)
class Verification(models.Model):
advertisement = models.ForeignKeyField(Advertisement)
key = models.CharField(max_length=32)
def gen_key(sender, instance, created, **kwargs):
code goes here
post_save.connect(gen_key, sender=Sale, dispatch_uid="my_unique_identifier")
接下来的问题是:“我该如何在post_save()中使用父类?”
1 个回答
5
与其连接到一个特定的发送者,不如直接连接到 post_save 这个事件,然后在你的处理函数中检查保存的实例的类型,比如:
def gen_key(sender, **kwargs):
if issubclass(sender, Advertisement):
code goes here
post_save.connect(gen_key, dispatch_uid="my_unique_identifier")