深入理解Django自定義信號(signals)
django中自定義了一些singals,用于監(jiān)聽一些操作,并發(fā)出通知
官方解釋:
Django 提供一個“信號分發(fā)器”,允許解耦的應用在框架的其它地方發(fā)生操作時會被通知到。
簡單來說,信號允許特定的sender通知一組receiver某些操作已經(jīng)發(fā)生。這在多處代碼和同一事件有關聯(lián)的情況下很有用。
django中已經(jīng)內置了一些singals,在django/db/models/signal.py中,如
Model signals pre_init # django的modal執(zhí)行其構造方法前,自動觸發(fā) post_init # django的modal執(zhí)行其構造方法后,自動觸發(fā) pre_save # django的modal對象保存前,自動觸發(fā) post_save # django的modal對象保存后,自動觸發(fā) pre_delete # django的modal對象刪除前,自動觸發(fā) post_delete # django的modal對象刪除后,自動觸發(fā) m2m_changed # django的modal中使用m2m字段操作第三張(add,remove,clear)前后,自動觸發(fā) class_prepared # 程序啟動時,檢測已注冊的app中modal類,對于每一個類,自動觸發(fā) Management signals pre_migrate # 執(zhí)行migrate命令前,自動觸發(fā) post_migrate # 執(zhí)行migrate命令后,自動觸發(fā) Request/response signals request_started # 請求到來前,自動觸發(fā) request_finished # 請求結束后,自動觸發(fā) got_request_exception # 請求異常后,自動觸發(fā) Test signals setting_changed # 使用test測試修改配置文件時,自動觸發(fā) template_rendered # 使用test測試渲染模板時,自動觸發(fā) Database Wrappers connection_created # 創(chuàng)建數(shù)據(jù)庫連接時,自動觸發(fā)
用法:
利用這幾個singals可以實現(xiàn)model中的一些聯(lián)動操作,比如,要想更改通過model更新記錄時,記下操作者的日志,可以直接在操作的地方使用post_save裝飾器,
或者改寫post_save,使其記錄相關信息,一勞永逸?;蛘咴趓equest請求時,記錄請求信息。
from django.core.signals import request_finished from django.dispatch import receiver @receiver(request_finished) def my_callback(sender, **kwargs): print("Request finished!")
如何自定義singals?
a. 定義singal文件
import django.dispatch pizza_done = django.dispatch.Signal(providing_args=["toppings", "size"])
b. 注冊singal
def callback(sender, **kwargs): print("callback") print(sender,kwargs) pizza_done.connect(callback)
c. 觸發(fā)信號
from 路徑 import pizza_done pizza_done.send(sender='seven',toppings=123, size=456)
需求場景:
項目中有一個需求,當model(即庫的數(shù)據(jù))被修改或者刪除時,自動觸發(fā)一個redis的同步任務(后來發(fā)現(xiàn)這個需求沒有意義....),model的保存有post_save,刪除有post_delete,唯獨沒有update,而代碼中使用update的場景蠻多的,就搜了下為什么就是沒有update的singals。
看到:https://code.djangoproject.com/ticket/12184
其實很早就有人給django官方提過這種方式,為什么不在官方版本中添加,具體這個pr為什么沒有被接受,可以看下里面的討論,反正當時的django1.9仍然不支持,只能自己先寫一個用用,有問題了再撤掉好了。
解決方式:
singals.py文件
# coding:utf-8 from django.dispatch import Signal post_update = Signal(providing_args=["user"])
models.py文件
-----------針對某個model,重寫其queryset中的update方法-----------
//引入自定義的signal文件 from tools import signals class MyCustomQuerySet(models.query.QuerySet): def update(self, **kwargs): super(MyCustomQuerySet, self).update(**kwargs) //update被調用時, 發(fā)送該singalsignals signals.post_update.send(sender=self.model, user="xxx") print("finished!") class MyCustomManager(models.Manager): def get_queryset(self): return MyCustomQuerySet(self.model, using=self._db) class crontab_ping(models.Model): name = models.CharField(max_length=64, blank=True, null=True) objects = MyCustomManager()
callback.py文件:
-------接收signal,觸發(fā)操作----------
from tools.signals import post_update @receiver(post_update) def post_update_callback(sender, **kwargs): print(kwargs['user']) print("post_update_success")
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
Python 字符串操作(string替換、刪除、截取、復制、連接、比較、查找、包含、大小寫轉換、分割等)
這篇文章主要介紹了Python 字符串操作(string替換、刪除、截取、復制、連接、比較、查找、包含、大小寫轉換、分割等),需要的朋友可以參考下2018-03-03使用Python字典實現(xiàn)詞頻統(tǒng)計的方法
在Python中,利用字典進行詞頻統(tǒng)計是一種常見且強大的方式,通過對文本進行預處理并使用字典數(shù)據(jù)結構,可以輕松地統(tǒng)計文本中每個單詞出現(xiàn)的頻率,下面將詳細解釋這個過程,并提供多種例子,以幫助你更好地理解并應用這一技術,需要的朋友可以參考下2023-12-12Python中排序函數(shù)sorted()函數(shù)的使用實例
sorted()作為Python內置函數(shù)之一,其功能是對序列(列表、元組、字典、集合、還包括字符串)進行排序,下面這篇文章主要給大家介紹了關于Python中排序函數(shù)sorted()函數(shù)的相關資料,需要的朋友可以參考下2022-11-11OpenCV中resize函數(shù)插值算法的實現(xiàn)過程(五種)
最新版OpenCV2.4.7中,cv::resize函數(shù)有五種插值算法:最近鄰、雙線性、雙三次、基于像素區(qū)域關系、蘭索斯插值。感興趣的可以了解一下2021-06-06基于matplotlib+tkinter實現(xiàn)簡單的繪圖系統(tǒng)
在理解matplotlib嵌入到tkinter中的原理之后,就已經(jīng)具備了打造繪圖系統(tǒng)的技術基礎,所以本文來實現(xiàn)一個簡單的繪圖系統(tǒng),感興趣的小伙伴小伙伴可以了解一下2023-08-08