国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁技術文章
文章詳情頁

Django在Model保存前記錄日志實例

瀏覽:194日期:2024-10-06 11:39:44

Django中如何在Model保存前做一定的固定操作,比如寫一句日志?

關鍵詞: 信號

利用Django的Model的Signal Dispatcher, 通過django.db.models.signals.pre_save() 方法,在事件發生前,

發射

觸發信號,這一切都被調度中的receiver方法深藏功與名的保存了。

信號的處理一般都寫在Model中,舉個例子:

import loggingfrom django.db import modelsfrom django.db.models.signals import pre_savefrom django.dispatch import receiver class Order(models.Model): # ... logger = logging.getLogger(__name__) @receiver(pre_save, sender=Order)def pre_save_handler(sender, **kwargs): # 我們可以在Order這個Model保存之前盡情調戲了:) logger.debug('{}'.format(sender, **kwargs)) print ’fuck universe’

這樣應該就實現了題中的要求,類似的方法還有比如 pre_init 是在Model實例之前會觸發, post_init 在實例之后觸發,同理就是 pre_save 和 post_save 了。

補充知識:Django models.save()的問題

Django views.py 引用models.py進行modles.objects.create()然后進行.save的問題。

我們是不能直接進行保存的,提交到數據庫里面的。

EX:

我們這里通過post獲取到信息后。

views.py

def post(self, request, ab=None, all_seat=None): # 獲取用戶信息 date = request.POST.get(’date’) time = request.POST.get(’time’)

然后

views.py

seatform = SeatForm(request.POST) # 提交給數據庫 #這里的is_valid()是Django默認的,檢查是否正確if seatform.is_valid(): # 這里向數據庫新增一條信息,然后保存 getSeat = Seat.objects.create(dateTime=date, classtime=time, status=’0’, user=name, number=label) getSeat.save()

上面的SeatForm()是我們在與views.py同級目錄下創建的forms.py

forms.py

class SeatForm(forms.Form):#注意這里的date和time需要與前端的命名要一直 date = forms.CharField() time = forms.CharField()

通過這樣的方法,我們就可以保存到數據庫了。

以上這篇Django在Model保存前記錄日志實例就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Django
相關文章:
主站蜘蛛池模板: 寿光市| 景洪市| 右玉县| 澎湖县| 如皋市| 综艺| 秦皇岛市| 泽州县| 博客| 孝昌县| 鄂尔多斯市| 张家港市| 双流县| 湾仔区| 鄂伦春自治旗| 府谷县| 富宁县| 嘉兴市| 礼泉县| 绿春县| 沧源| 英德市| 潞城市| 滨海县| 镇雄县| 信宜市| 玉屏| 道真| 梅河口市| 盘山县| 湖州市| 柳河县| 宜兰县| 漯河市| 漾濞| 驻马店市| 错那县| 永昌县| 炉霍县| 安新县| 吉木萨尔县|