欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品

主頁 > 知識庫 > django如何自定義manage.py管理命令

django如何自定義manage.py管理命令

熱門標簽:悟空智電銷機器人6 遼寧400電話辦理多少錢 溫州旅游地圖標注 電信營業(yè)廳400電話申請 荊州云電銷機器人供應商 外呼不封號系統(tǒng) 幫人做地圖標注收費算詐騙嗎 江蘇房產電銷機器人廠家 蘇州電銷機器人十大排行榜

每次在啟動Django服務之前,我們都會在終端運行python manage.py xxx的管理命令。其實我們還可以自定義管理命令,這對于執(zhí)行獨立的腳本或任務非常有用,比如清除緩存、導出用戶郵件清單或發(fā)送郵件等等。

自定義的管理命令不僅可以通過manage.py運行,還可以通過Linux或Celery的crontab服務將其設成定時任務。本文主要講解如何自定義Django-admin命令,并提供一些演示案例。

自定義Django-admin命令一共分三步:創(chuàng)建文件夾布局、編寫命令代碼和測試使用。

創(chuàng)建文件夾布局

自定義的Django-admin管理命令本質上是一個python腳本文件,它的存放路徑必須遵循一定的規(guī)范,一般位于app/management/commands目錄。整個文件夾的布局如下所示:

 app01/
    __init__.py
    models.py
    management/
        __init__.py
        commands/
            __init__.py
            _private.py # 以下劃線開頭文件不能用作管理命令
            my_commands.py # 這個就是自定義的管理命令腳本,文件名即為命令名
    tests.py
    views.py

注意:

  • management和commands每個目錄下都必須有個__init__.py空文件,表明這是一個python包。另外以下劃線開頭的文件名不能用作管理命令腳本。
  • management/commands目錄可以位于任何一個app的目錄下,Django都能找到它。
  • 一般建議每個python腳本文件對應一條管理命令。

編寫命令代碼

每一個自定義的管理命令本質是一個Command類, 它繼承了Django的Basecommand或其子類, 主要通過重寫handle()方法實現自己的業(yè)務邏輯代碼,而add_arguments()則用于幫助處理命令行的參數,如果運行命令時不需要額外參數,可以不寫這個方法。

 from django.core.management.base import BaseCommand
 
 class Command(BaseCommand):
     # 幫助文本, 一般備注命令的用途及如何使用。
     help = 'Some help texts'
 
     # 處理命令行參數,可選
     def add_arguments(self, parser):
        pass
 
     # 核心業(yè)務邏輯
     def handle(self, *args, **options):
         pass

我們現在來看一個最簡單的例子,希望定義一個名為hello_world的命令。這樣當我們運行python manage.py hello_world命令時,控制臺會打印出Hello World!字樣。在app/management/commands目錄下新建hello_world.py, 添加如下代碼:

 from django.core.management.base import BaseCommand
 
 class Command(BaseCommand):
    # 幫助文本, 一般備注命令的用途及如何使用。
    help = "Print Hello World!"
 
    # 核心業(yè)務邏輯
    def handle(self, *args, **options):
        self.stdout.write('Hello World!')

注意:當你使用管理命令并希望在控制臺輸出指定信息時,你應該使用self.stdout和self.stderr方法,而不能直接使用python的print方法。另外,你不需要在消息的末尾加上換行符,它將被自動添加。

此時當你進入項目文件夾運行python manage.py hello_world命令時,你將得到如下輸出結果:

現在我們來增加點難度,來通過命令行給hello_world命令傳遞一個name參數,以實現運行python manage.py helloworld John命令時 打印出Hello World! John。

現在修改我們的hello_world.py, 添加add_arguments方法,該方法的作用是給自定義的handle方法添加1個或多個參數。

 from django.core.management.base import BaseCommand
 
 class Command(BaseCommand):
    # 幫助文本, 一般備注命令的用途及如何使用。
    help = "Print Hello World!"
 
    # 給命令添加一個名為name的參數
    def add_arguments(self, parser):
        parser.add_argument('name')
 
    # 核心業(yè)務邏輯,通過options字典接收name參數值,拼接字符串后輸出
    def handle(self, *args, **options):
        msg = 'Hello World ! '+ options['name']
        self.stdout.write(msg)

此時當你再次運行python manage.py hello_world John命令時,你將得到如下輸出結果:

如果你直接運行命令而不攜帶參數,將會報錯,如下所示:

實際應用場景

前面的案例過于簡單,我們現在來看兩個自定義管理命令的實際應用案例。

案例1:檢查數據庫連接是否已就緒

無論你使用常規(guī)方式還是Docker在生產環(huán)境中部署Django項目,你需要確保數據庫連接已就緒后才進行數據庫遷移(migrate)的命令(Docker-compose的depends選項并不能確保這點),否則Django應用程序會出現報錯。

這時你可以自定義一個wait_for_db的命令,如下所示:

 # app/management/commands/wait_for_db.py
 
 import time
 from django.db import connections
 from django.db.utils import OperationalError
 from django.core.management import BaseCommand
 
 
 class Command(BaseCommand):
     help = 'Run data migrations until db is available.'
 
     def handle(self, *args, **options):
         self.stdout.write('Waiting for database...')
         db_conn = None
         while not db_conn:
             try:
                 # 嘗試連接
                 db_conn = connections['default']
             except OperationalError:
                 # 連接失敗,就等待1秒鐘
                 self.stdout.write('Database unavailable, waiting 1 second...')
                 time.sleep(1)
 
         self.stdout.write(self.style.SUCCESS('Database available!'))

定義好這個命令后每次在運行python manage.py migrate命令前先運行python manage.py wait_for_db即可。

案例2:周期性發(fā)送郵件

如果你是網站管理員,你肯定希望知道每天有多少新用戶已注冊,這時你可以自定義一條mail_admin的管理命令,將每天新注冊用戶數量以郵件形式發(fā)給自己,如下所示:

 # app/management/commands/mail_admin.py
 
 #-*- coding:utf-8 -*-
 from datetime import timedelta, time, datetime
 from django.core.mail import mail_admins
 from django.core.management import BaseCommand
 from django.utils import timezone
 from django.contrib.auth import get_user_model
 
 User = get_user_model()
 
 today = timezone.now()
 yesterday = today - timedelta(1)
 
 
 class Command(BaseCommand):
     help = "Send The Daily Count of New Users to Admins"
 
     def handle(self, *args, **options):
         # 獲取過去一天注冊用戶數量
         user_count =User.objects.filter(date_joined__range=(yesterday, today)).count()
         
         # 當注冊用戶數量多余1個,才發(fā)送郵件給管理員
         if user_count >= 1:
             message = "You have got {} user(s) in the past 24 hours".format(user_count)
 
             subject = (
                 f"New user count for {today.strftime('%Y-%m-%d')}: {user_count}"
            )
 
             mail_admins(subject=subject, message=message, html_message=None)
 
             self.stdout.write("E-mail was sent.")
         else:
             self.stdout.write("No new users today.")

如果你在終端運行python manage.py mail_admin命令,你將得到如下輸出結果:

注意:真正發(fā)送郵件成功需要設置Email后臺及管理員,測試環(huán)境下可以使用如下簡單配置:

 EMAIL_BACKEND = "django.core.mail.backends.console.EmailBackend"
 DEFAULT_FROM_EMAIL = "noreply@example.com"
 ADMINS = [("大江狗", "yunbo.shi@example.com"), ]

但是如果每天都要進入終端運行這個命令實在太麻煩了,我們完全可以使用Linux的crontab服務或Celery-Beat將其設成周期性定時任務task,這時只需要調用Django的call_command方法即可。

 # app/tasks.py, 可以任一app目錄下新建task
 from celery import shared_task
 from django.core.management import call_command
 
 @shared_task
 def mail_admin():
     call_command("mail_admin", )

關于Django項目中如何使用Celery執(zhí)行異步和周期性任務,請參加下篇Django進階-異步和周期任務篇。

以上就是django如何自定義manage.py管理命令的詳細內容,更多關于django 自定義manage.py管理命令的資料請關注腳本之家其它相關文章!

您可能感興趣的文章:
  • 關于django python manage.py startapp 應用名出錯異常原因解析
  • django manage.py擴展自定義命令方法
  • django 解決manage.py migrate無效的問題

標簽:臺灣 喀什 宿遷 欽州 景德鎮(zhèn) 三沙 濟南 黃山

巨人網絡通訊聲明:本文標題《django如何自定義manage.py管理命令》,本文關鍵詞  django,如何,自定義,manage.py,;如發(fā)現本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統(tǒng)采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《django如何自定義manage.py管理命令》相關的同類信息!
  • 本頁收集關于django如何自定義manage.py管理命令的相關信息資訊供網民參考!
  • 推薦文章
    欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品
  • <rt id="w000q"><acronym id="w000q"></acronym></rt>
  • <abbr id="w000q"></abbr>
    <rt id="w000q"></rt>
    欧美视频你懂的| 亚洲综合一二区| 久久疯狂做爰流白浆xx| 国产精品嫩草av| 欧美一区二区在线播放| 丝袜亚洲精品中文字幕一区| 国产成人精品综合久久久久99 | 国产中文av在线| 国产亚洲精品免费| 国产精品资源站在线| 91麻豆制片厂| 中文欧美字幕免费| 不卡一卡二卡三乱码免费网站| 国产suv精品一区二区68| 国产精品素人视频| 不卡一区在线观看| 欧美在线免费播放| 亚洲成人1区2区| 黄色片视频免费观看| 欧美成人免费网站| 狂野欧美性猛交blacked| 99久久久无码国产精品衣服| 色天使在线视频| 欧美一区二区三区思思人| 日本欧美一区二区| 精品人伦一区二区三电影| 久久人人爽人人爽| 高清久久久久久| 色婷婷av一区二区三区gif| 亚洲精品久久久蜜桃| 性欧美18—19sex性高清| 日韩一区二区三区电影| 久久成人18免费观看| 日本爱爱小视频| 亚洲伦理在线免费看| 制服丝袜在线第一页| 精品国一区二区三区| 国产精品夜夜嗨| 日本大香伊一区二区三区| 亚洲成a人片在线不卡一二三区| 韩国无码一区二区三区精品| 精品盗摄一区二区三区| 国产+成+人+亚洲欧洲自线| 欧美中文字幕一区| 日本成人在线电影网| 国精产品视频一二二区| 亚洲欧美日韩国产中文在线| 中文字幕在线播放一区| 国产日韩欧美综合在线| 初高中福利视频网站| 日韩欧美在线综合网| 国产成人aaa| 欧美久久久久久久久久| 激情国产一区二区 | 中文字幕一区不卡| 国产综合内射日韩久| 久久免费视频色| 久久久久久国产精品日本| 精品日韩99亚洲| 99久久精品免费精品国产| 欧美一级夜夜爽| 国产精品天美传媒沈樵| 日韩成人av影院| 国产欧美精品一区二区色综合| 又大又长粗又爽又黄少妇视频| 久久先锋资源网| 国产伦理在线观看| 国产日产欧美一区二区视频| 日本wwwwwww| 国产精品无码永久免费888| 精品国产aⅴ一区二区三区东京热| 久久一二三国产| 永久免费看片在线观看| 久久久久久久久久久久久久久99| 亚洲av无一区二区三区久久| 久久久久免费观看| 国产69视频在线观看| 国产精品狼人久久影院观看方式| 天天插天天射天天干| 日韩一区在线播放| 欧美大波大乳巨大乳| 亚洲五月六月丁香激情| 日本 欧美 国产| 美女任你摸久久| 欧美日韩国产乱码电影| 福利一区二区在线| 精品国产一区二区三区久久影院| 91视频你懂的| 国产精品色一区二区三区| 播金莲一级淫片aaaaaaa| 亚洲资源中文字幕| 老妇女50岁三级| 狠狠色综合日日| 日韩免费性生活视频播放| 日本黄色www| 国产精品美女久久久久久久| 国产jjizz一区二区三区视频| 午夜精品久久久| 91国偷自产一区二区三区观看| 国产精品自拍在线| 欧美videossexotv100| 涩视频在线观看| 亚洲另类中文字| 欧美丰满熟妇bbbbbb| 久久综合九色欧美综合狠狠| 国产激情视频网站| 亚洲综合视频网| 一本大道综合伊人精品热热| 国产精品资源网站| 久久午夜老司机| 亚洲精品国产一区黑色丝袜| 亚洲午夜激情av| 欧美亚洲综合色| 一本色道a无线码一区v| 国产精品日韩成人| 小早川怜子久久精品中文字幕| 视频在线观看一区二区三区| 欧美日韩三级一区二区| jlzzjlzz亚洲日本少妇| 国产精品久久午夜夜伦鲁鲁| 亚洲女人久久久| 国产成人亚洲综合a∨婷婷图片| 久久久亚洲精品石原莉奈| 人妻无码一区二区三区| 日韩精品乱码免费| 欧美一区二区三区喷汁尤物| 亚洲精品乱码久久| 五月天激情综合| 欧美一区二区三区的| 在线观看国产三级| 蜜桃视频一区二区| 欧美精品一区二区三区蜜桃 | 欧美肥大bbwbbw高潮| 亚洲精品成人无码毛片| 亚洲综合精品久久| 欧美久久久久久蜜桃| xxxxxx黄色| 毛片不卡一区二区| 久久综合狠狠综合久久综合88| 91网站免费入口| 国产自产2019最新不卡| 日本一区二区视频在线| 久草视频手机在线| 99久久精品免费看国产| 亚洲愉拍自拍另类高清精品| 51精品视频一区二区三区| 久久人人妻人人人人妻性色av| 美女在线一区二区| 国产亚洲短视频| 午夜69成人做爰视频| 亚洲区小说区图片区qvod| 91久久精品网| 扒开伸进免费视频| 老司机午夜精品99久久| 国产日韩av一区| 色94色欧美sute亚洲13| 亚洲无人区码一码二码三码| 男人的天堂久久精品| 国产亚洲一区字幕| 午夜激情福利网| 波多野结衣电影免费观看| 日韩1区2区日韩1区2区| 久久毛片高清国产| 国产精品久久久久久久精| 国产香蕉精品视频| 狠狠色丁香久久婷婷综| 成人欧美一区二区三区黑人麻豆 | 一区二区高清免费观看影视大全 | 欧美三级乱人伦电影| 国产吞精囗交久久久| 国产精华液一区二区三区| 一区二区三区不卡视频| 欧美电视剧在线看免费| 青花影视在线观看免费高清| 亚洲熟妇一区二区| 国内精品免费**视频| 亚洲激情校园春色| 精品处破学生在线二十三| 色偷偷久久一区二区三区| 影音先锋黄色资源| 国产盗摄精品一区二区三区在线| 一区二区三区日韩欧美精品| 久久综合九色综合97婷婷| 91高清在线观看| av黄色免费网站| 99re成人在线| 久久aⅴ国产欧美74aaa| 亚洲自拍另类综合| 国产情人综合久久777777| 欧美二区三区91| 男女性高潮免费网站| 中文乱码人妻一区二区三区视频| 成人综合在线网站| 日韩精品一级二级| 亚洲三级在线看| 精品国产乱码久久久久久1区2区 | 亚洲大片一区二区三区| 国产亚洲一本大道中文在线| 欧美日韩mp4| 一本一道久久a久久精品综合蜜臀|