Django信号量
摘自官方文档
使用
信号
模型信号
警告
如果在模型上覆盖这些方法,则必须调用父类的方法来发送此信号。
注解
sender
通过指定其完整的应用标签来连接接收器时,可以懒惰地引用模型信号模型。例如,应用程序中Answer
定义的 模型polls
可以引用为'polls.Answer'
。在处理循环导入依赖项和可交换模型时,这种引用非常方便。pre_init
每当您实例化Django模型时,此信号都会在模型
__init__()
方法的开头发送。使用此信号发送的参数:
sender
- 刚创建实例的模型类。
args
- 传递给的位置参数列表
__init__()
: kwargs
- 传递给关键字参数的字典
__init__()
:
p = Poll(question="What's up?", pub_date=datetime.now())
争论 | 值 |
sender |
Poll (班级本身) |
args |
[] (一个空列表,因为没有传递给位置参数__init__() 。) |
kwargs |
{'question': "What's up?", 'pub_date': datetime.now()} |
post_init
和pre_init一样,但是这个
__init__()
方法在方法完成时发送。使用此信号发送的参数:
sender
- 如上所述:刚创建实例的模型类。
instance
- 刚刚创建的模型的实际实例。
pre_save
使用此信号发送的参数:
sender
- 模型类。
instance
- 保存的实际实例。
raw
- 布尔值;
True
如果模型完全按照提供的方式保存(即加载夹具时)。不应该查询/修改数据库中的其他记录,因为数据库可能尚未处于一致状态。 using
- 正在使用的数据库别名。
update_fields
- 要传递给更新的字段集
Model.save()
,或者None
如果update_fields
未传递给它save()
。
post_save
- django.db.models.signals.post_save¶
使用此信号发送的参数:
sender
- 模型类。
instance
- 保存的实际实例。
created
- 布尔值;
True
如果创建了新记录。 raw
- 布尔值;
True
如果模型完全按照提供的方式保存(即加载夹具时)。不应该查询/修改数据库中的其他记录,因为数据库可能尚未处于一致状态。 using
- 正在使用的数据库别名。
update_fields
- 要传递给更新的字段集
Model.save()
,或者None
如果update_fields
未传递给它save()
。
pre_delete
使用此信号发送的参数:
sender
- 模型类。
instance
- 要删除的实际实例。
using
- 正在使用的数据库别名。
pre_delete
使用此信号发送的参数:
sender
- 模型类。
instance
-
要删除的实际实例。请注意,该对象将不再存在于数据库中,因此请谨慎对待此实例。
using
- 正在使用的数据库别名。
m2m_changed
ManyToManyField
在模型实例上更改a 时发送。严格来说,这不是一个模型信号,因为它是由它发送的 ManyToManyField
,但由于它补充了 pre_save
/ post_save
和pre_delete
/ post_delete
当跟踪模型的变化时,它包含在这里。使用此信号发送的参数:
sender
- 中间模型类描述
ManyToManyField
。定义多对多字段时,将自动创建此类; 您可以使用through
多对多字段中的属性访问它 。 instance
- 更新多对多关系的实例。这可以是与之相关
sender
的类的实例,也可以ManyToManyField
是与之相关的类的 实例。 action
-
一个字符串,指示对关系执行的更新类型。这可以是以下之一:
"pre_add"
- 在将一个或多个对象添加到关系之前发送。
"post_add"
- 将一个或多个对象添加到关系后发送。
"pre_remove"
- 在从关系中删除一个或多个对象之前发送。
"post_remove"
- 从关系中删除一个或多个对象后发送。
"pre_clear"
- 在关系被清除之前发送。
"post_clear"
- 关系清除后发送。
reverse
- 指示关系的哪一侧更新(即,是否正在修改正向或反向关系)。
model
- 从关系中添加,删除或清除的对象的类。
pk_set
-
对于
pre_add
,post_add
,pre_remove
和post_remove
的动作,这是一组已被添加到或从关系移除主键值。对于pre_clear
和post_clear
行动,这是None
。 using
- 正在使用的数据库别名。
例如,如果a
Pizza
可以有多个Topping
对象,则建模如下:class Topping(models.Model): # ... pass class Pizza(models.Model): # ... toppings = models.ManyToManyField(Topping) 如果我们连接这样的处理程序: from django.db.models.signals import m2m_changed def toppings_changed(sender, **kwargs): # Do something pass m2m_changed.connect(toppings_changed, sender=Pizza.toppings.through)
然后做了这样的事情:
>>> p = Pizza.objects.create(...)
>>> t = Topping.objects.create(...)
>>> p.toppings.add(t)
争论 | 值 |
sender |
Pizza.toppings.through (中级m2m级) |
instance |
p (Pizza 正在修改的实例) |
action |
"pre_add" (后跟一个单独的信号"post_add" ) |
reverse |
False (Pizza 包含 ManyToManyField ,所以这个调用修改了前向关系) |
model |
Topping (添加到的对象的类 Pizza ) |
pk_set |
{t.id} (因为只添加到关系中)Topping t |
using |
"default" (因为默认路由器在这里发送写入) |
如果我们这样做的话:
>>> t.pizza_set.remove(p)
争论 | 值 |
sender |
Pizza.toppings.through (中级m2m级) |
instance |
t (Topping 正在修改的实例) |
action |
"pre_remove" (后跟一个单独的信号"post_remove" ) |
reverse |
True (Pizza 包含 ManyToManyField ,所以这个调用修改了反向关系) |
model |
Pizza (从中删除的对象的类 Topping ) |
pk_set |
{p.id} (因为只从关系中删除)Pizza p |
using |
"default" (因为默认路由器在这里发送写入) |
class_prepared
每当模型类被“准备好”时发送 - 也就是说,一旦定义了模型并在Django的模型系统中注册。Django在内部使用这个信号; 它通常不用于第三方应用程序。
由于此信号是在app注册表填充过程中发送的,并且
AppConfig.ready()
在app注册表完全填充后运行,因此无法在该方法中连接接收器。一种可能性是连接它们AppConfig.__init__()
,注意不要导入模型或触发对app注册表的调用。使用此信号发送的参数:
sender
- 刚准备的模型类。
管理信号
django-admin发送的信号。
pre_migrate
使用此信号发送的参数:
sender
AppConfig
要迁移/同步的应用程序的实例。app_config
- 与...相同
sender
。 verbosity
interactive
-
如果
interactive
是True
,则提示用户在命令行上输入内容是安全的。如果interactive
是False
,侦听此信号的功能不应尝试提示任何内容。 using
- 命令将在其上运行的数据库的别名。
plan
- 将用于迁移运行的迁移计划。虽然该计划不是公共API,但这允许在必要时知道该计划的极少数情况。计划是两元组的列表,第一项是迁移类的实例,第二项显示迁移是否已回滚(
True
)或已应用(False
)。 apps
Apps
在迁移运行之前包含项目状态的实例。应该使用它来代替全局apps
注册表来检索要对其执行操作的模型。
post_migrate
使用此信号发送的参数:
sender
AppConfig
刚刚安装的应用程序的实例。app_config
- 与...相同
sender
。 verbosity
interactive
-
如果
interactive
是True
,则提示用户在命令行上输入内容是安全的。如果interactive
是False
,侦听此信号的功能不应尝试提示任何内容。 using
- 用于同步的数据库别名。默认为
default
数据库。 plan
- 用于迁移运行的迁移计划。虽然该计划不是公共API,但这允许在必要时知道该计划的极少数情况。计划是两元组的列表,第一项是迁移类的实例,第二项显示迁移是否已回滚(
True
)或已应用(False
)。 apps
Apps
迁移运行后包含项目状态的实例。应该使用它来代替全局apps
注册表来检索要对其执行操作的模型。
class Topping(models.Model): # ... pass class Pizza(models.Model): # ... toppings = models.ManyToManyField(Topping) 如果我们连接这样的处理程序: from django.db.models.signals import m2m_changed def toppings_changed(sender, **kwargs): # Do something pass m2m_changed.connect(toppings_changed, sender=Pizza.toppings.through)
注解
如果您提供
AppConfig
实例作为sender参数,请确保已注册信号 ready()
。AppConfig
对于使用修改集INSTALLED_APPS
(例如,当覆盖设置时)运行的测试,将重新创建s,并且应为每个新AppConfig
实例连接此类信号。请求/响应信号
处理请求时核心框架发送的信号。
request_started
Django开始处理HTTP请求时发送。
使用此信号发送的参数:
sender
- 处理程序类 - 例如
django.core.handlers.wsgi.WsgiHandler
- 处理请求。 environ
environ
提供给请求的字典。
got_request_exception
只要Django在处理传入的HTTP请求时遇到异常,就会发送此信号。
使用此信号发送的参数:
sender
- 处理程序类,如上所述。
request
- 的
HttpRequest
对象。
测试信号
宁可清贫自乐,不可浊富多忧