Django信号量signals总结使用

Django信号量

#0 GitHub

https://github.com/Coxhuang/django-signals.git

#1 环境

python3.6
django==2.0.7

#2 需求

  • 老板要求,每次数据库迁移时,变量a自增
  • 老板要求,每次数据库D有新的数据添加进去时,变量b自增
  • … …

#3 设置

#3.1 新建一个django项目

#3.2 配置文件

#3.2.1 目录结构

.
├── app
│   ├── __init__.py
│   ├── admin.py
│   ├── apps.py
│   ├── migrations
│   ├── models.py
│   ├── signal.py # 新增文件
│   ├── tests.py
│   └── views.py
├── db.sqlite3
├── manage.py
├── signals
│   ├── __init__.py
│   ├── settings.py
│   ├── urls.py
│   └── wsgi.py
└── templates

#3.2.2 修改./app/apps.py

from django.apps import AppConfig


class AppConfig(AppConfig):
    name = 'app'

    def ready(self):
        import app.signal # signal.py路径

#3.2.3 修改./app/init.py

default_app_config = 'app.apps.AppConfig' # apps.py文件中类名

#3.2.4 新增./app/signal.py

from django.dispatch import receiver
from django.db.models.signals import pre_save, post_save
from django.db.backends.signals import connection_created
from django.db.models.signals import pre_migrate, post_migrate
from django.core.signals import request_finished
from django.core.signals import request_started
from django.core.signals import got_request_exception
from django.db.models.signals import class_prepared
from django.db.models.signals import pre_init, post_init
from django.db.models.signals import pre_save, post_save
from django.db.models.signals import pre_delete, post_delete
from django.db.models.signals import m2m_changed
from django.db.models.signals import pre_migrate, post_migrate
from django.test.signals import setting_changed
from django.test.signals import template_rendered
from django.db.backends.signals import connection_created

@receiver(post_migrate)
def callback_post_migrate(sender, **kwargs):
    print("这里是--post_migrate--")
    return None

#3.3 效果

在这里插入图片描述

#4 其他触发机制

Model signals

pre_init                    # django的modal执行其构造方法前,自动触发
post_init                   # django的modal执行其构造方法后,自动触发
pre_save                    # django的modal对象保存前,自动触发
post_save                   # django的modal对象保存后,自动触发
pre_delete                  # django的modal对象删除前,自动触发
post_delete                 # django的modal对象删除后,自动触发
m2m_changed                 # django的modal中使用m2m字段操作第三张表(add,remove,clear)前后,自动触发
class_prepared              # 程序启动时,检测已注册的app中modal类,对于每一个类,自动触发

Management signals

pre_migrate                 # 执行migrate命令前,自动触发
post_migrate                # 执行migrate命令后,自动触发

Request/response signals

request_started             # 请求到来前,自动触发
request_finished            # 请求结束后,自动触发
got_request_exception       # 请求异常后,自动触发

Test signals

setting_changed             # 使用test测试修改配置文件时,自动触发
template_rendered           # 使用test测试渲染模板时,自动触发

Database Wrappers

connection_created          # 创建数据库连接时,自动触发

导入

from django.core.signals import request_finished
from django.core.signals import request_started
from django.core.signals import got_request_exception
from django.db.models.signals import class_prepared
from django.db.models.signals import pre_init, post_init
from django.db.models.signals import pre_save, post_save
from django.db.models.signals import pre_delete, post_delete
from django.db.models.signals import m2m_changed
from django.db.models.signals import pre_migrate, post_migrate
from django.test.signals import setting_changed
from django.test.signals import template_rendered
from django.db.backends.signals import connection_created

@receiver(post_migrate)
def callback_post_migrate(sender, **kwargs):
    print("这里是--post_migrate--")
    return None
Django的信号(Signals)是一种在应用程序中发送和接收通知的机制。它允许不同的组件之间进行解耦,以便在某个事件发生时,一个组件可以通知其他组件执行一些特定的操作。 在Django中,信号可以用于各种用途,比如在数据库操作之前或之后执行某些逻辑、在用户注册成功后发送欢迎邮件等。 要使用信号,首先需要定义一个信号发送者(signal sender),然后定义一个接收者(signal receiver)来处理信号。 以下是一个使用Django信号的简单示例: ```python from django.db.models.signals import post_save from django.dispatch import receiver from django.contrib.auth.models import User @receiver(post_save, sender=User) def create_profile(sender, instance, created, **kwargs): if created: Profile.objects.create(user=instance) @receiver(post_save, sender=User) def save_profile(sender, instance, **kwargs): instance.profile.save() ``` 在上面的示例中,我们定义了两个接收者函数,分别是`create_profile`和`save_profile`。这两个函数都会接收到`post_save`信号,并在`User`模型实例保存后执行相应的操作。 要确保信号接收者能够正常工作,需要在Django应用程序的`apps.py`文件中注册信号接收器,并在`__init__.py`文件中导入`apps.py`模块。 请注意,信号的发送和接收是同步的,即发送信号的代码会等待所有接收者函数执行完毕后才会继续执行。 以上是关于Django信号的简要介绍,希望能对你有所帮助!如果你还有其他问题,请继续提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值