成人性生交大片免费看视频r_亚洲综合极品香蕉久久网_在线视频免费观看一区_亚洲精品亚洲人成人网在线播放_国产精品毛片av_久久久久国产精品www_亚洲国产一区二区三区在线播_日韩一区二区三区四区区区_亚洲精品国产无套在线观_国产免费www

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

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

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

每次在啟動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()方法實現(xiàn)自己的業(yè)務邏輯代碼,而add_arguments()則用于幫助處理命令行的參數(shù),如果運行命令時不需要額外參數(shù),可以不寫這個方法。

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

我們現(xiàn)在來看一個最簡單的例子,希望定義一個名為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命令時,你將得到如下輸出結果:

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

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

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

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

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

實際應用場景

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

案例1:檢查數(shù)據(jù)庫連接是否已就緒

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

這時你可以自定義一個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ā)送郵件

如果你是網(wǎng)站管理員,你肯定希望知道每天有多少新用戶已注冊,這時你可以自定義一條mail_admin的管理命令,將每天新注冊用戶數(shù)量以郵件形式發(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):
         # 獲取過去一天注冊用戶數(shù)量
         user_count =User.objects.filter(date_joined__range=(yesterday, today)).count()
         
         # 當注冊用戶數(shù)量多余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) 三沙 濟南 黃山

巨人網(wǎng)絡通訊聲明:本文標題《django如何自定義manage.py管理命令》,本文關鍵詞  django,如何,自定義,manage.py,;如發(fā)現(xiàn)本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《django如何自定義manage.py管理命令》相關的同類信息!
  • 本頁收集關于django如何自定義manage.py管理命令的相關信息資訊供網(wǎng)民參考!
  • 推薦文章
    美腿丝袜一区二区三区| 爱豆国产剧免费观看大全剧苏畅| 精品91久久久久| 日韩欧美中文字幕在线播放| 欧美伦理一区二区| 黄色美女一级片| 美国一区二区三区在线播放| 99国产精品国产精品久久| 美女写真理伦片在线看| 极品尤物一区二区三区| 亚洲激情校园春色| 亚洲精品免费在线观看视频| 国产麻豆视频| 不卡视频在线看| a级网站在线观看| 嫩草www视频在线观看高清| 国产高清不卡一区| 999久久久国产精品| 国产精品极品美女粉嫩高清在线| 久久精品99久久久香蕉| 久久精品人人做人人爽97| 色婷婷久久av| 国产96在线亚洲| 992tv在线成人免费观看| 久久国产日本精品| 一区二区不卡在线视频 午夜欧美不卡在| 免费h视频在线观看| 欧美一级淫片播放口| 国产一二区在线| 久久精品日韩精品| 免费在线观看一级片| 欧美日韩国产综合一区二区| 深夜福利视频在线免费观看| 成人国产精品久久久久久亚洲| 97婷婷涩涩精品一区| 黄页网址大全在线播放| 国产精品av一区| 免费a级观看| gogogo高清在线观看免费完整版| av毛片在线免费观看| 手机亚洲手机国产手机日韩| 欧美视频在线视频精品| 一区二区三区蜜桃网| 婷婷激情综合网| 久久久噜久噜久久综合| 成人免费a视频| 亚洲精品国产视频| 成人免费播放视频| 亚洲sss视频在线视频| 成人免费在线小视频| 国v精品久久久网| 亚洲精品69| 久久久国产综合精品女国产盗摄| 色午夜这里只有精品| 国产精品第56页| 激情五月婷婷综合| 激情综合色综合久久综合| 欧美国产在线视频| 爱福利一区二区| 欧美一区二不卡视频| 91蜜臀精品国产自偷在线| 99九九电视剧免费观看| 国产又黄又爽视频| 九9re精品视频在线观看re6| 国产一区二区三区四区五区六区| 中文字幕在线看人| 综合欧美亚洲日本| 警花av一区二区三区| 国产一级18片视频| 色88888久久久久久影院按摩| 欧美黑人性生活视频| 黄色网战入口| 国产精品手机播放| 欧美一级三级| 国产第一精品| 国产精品白丝在线| 精品久久久久成人码免费动漫| 色av中文字幕一区| 亚洲欧美在线免费观看| 亚洲激情午夜| 一级片免费在线观看| 欧美一区二区三区黄片| 喷水一区二区三区| 果冻天美麻豆一区二区国产| 香蕉视频在线视频| 亚洲欧美se| 中文字幕无码精品亚洲35| 99精品国产99久久久久久白柏| av中文在线资源库| 色综合久久综合网97色综合| 国色天香一区二区| 九九久久久久午夜精选| 中文在线a天堂| 一级视频在线观看视频在线啦啦| 日韩不卡一区二区三区| www.黄色网| 9色在线视频| 99久久免费国产| 国产综合av一区二区三区| 国产精品日韩一区二区三区| 国产精品乱码视频| 韩国久久久久久| 精品一区二区三区毛片| 午夜一级在线看亚洲| 久久丫精品忘忧草西安产品| 有色激情视频免费在线| 成人黄色中文字幕| 毛片一级免费一级| 国产又粗又猛视频| www.av中文字幕| 在线看片福利| 国产午夜精品福利| 日本高清成人免费播放| 亚洲免费av网站| 欧美亚洲日本网站| 国产精品综合不卡av| 五月天国产在线| 顶级欧美妇高清xxxxx| 国产夫妻在线视频| 国产伦理久久久久久妇女| 国产狼人综合免费视频| 欧美黑人经典片免费观看| 国产亚洲精彩久久| 影音先锋日韩av| 国产精品免费观看久久| 国产黄色精品视频| 日本在线三级| 亚洲丶国产丶欧美一区二区三区| 色欧美日韩亚洲| 欧美美女性视频| 色男人天堂综合再现| 一区二区三区免费在线观看视频| 全部孕妇毛片丰满孕妇孕交| 国产精品免费视频二三区| 乱小说综合网站| а√天堂8资源在线| 羞羞漫画网18久久app| 天天干天天插天天操| 中文av一区二区| 成人av福利| 国内精品久久久久久久影视蜜臀| 国产三级国产精品国产国在线观看| 国产亚洲美女久久| 一级黄在线观看| 亚洲AV无码国产成人久久| 久草在线国产| 欧美电影免费观看完整版| 一区二区三区欧美精品| 国产午夜精品全部视频播放| 欧美日韩大片一区二区三区| 中文文字幕文字幕高清| 久久久久久综合网| 精品视频一区三区九区| 香蕉视频禁止18| 丰满少妇被猛烈进入高清播放| 麻豆成人综合网| 无码人妻一区二区三区在线| 天天综合网在线观看| 伊人久久大香线蕉av一区| 欧美伊人久久久久久午夜久久久久| av国产精品| 亚洲第五色综合网| 国产欧美日韩在线观看视频| 国产嫩草一区二区三区在线观看| 天天操夜夜操夜夜操| 亚洲蜜桃视频| 99国产精品久久久| 激情黄产视频在线免费观看| 中文字幕免费视频| 欧美一级视频免费| av影片免费在线观看| 伊人久久综合视频| 国产精品18久久久久网站| 国产精品国色综合久久| 深夜福利网站在线观看| 亚洲精品一区国产| 久久国产视频播放| 亚洲精品福利视频网站| 黄色一级视频免费观看| 噜噜噜躁狠狠躁狠狠精品视频| 日韩一级视频免费观看在线| 91综合精品国产丝袜长腿久久| 69堂免费视频| 亚洲一区二区三区黄色| 婷婷亚洲久悠悠色悠在线播放| 国产亚洲免费的视频看| 亚洲欧美日韩国产手机在线| 日韩中文一区二区三区| 久久久久久久久久一级| 国产mv免费观看入口亚洲| 日本视频在线观看一区二区三区| 91免费看国产| 国产精品午夜一区二区三区| 国产精品一区二区三区网站| 精品一级视频| 亚洲国产欧美一区二区丝袜黑人| 91精品国产91久久久久| 青青青青国产视频| 成人444kkkk在线观看| 热久久最新网址| 牛夜精品久久久久久久| 真实的国产乱xxxx在线91| 一区二区三区波多野结衣在线观看| 精品人妻一区二区乱码| 丝袜a∨在线一区二区三区不卡| 亚洲香蕉视频| 欧美大交乱xxxxxbbb| 精品奇米国产一区二区三区| 欧美极品xxxx| 在线中文字幕一区二区| 亚洲一区二区在线视频观看| 牛夜精品久久久久久久99黑人| 无码日韩精品一区二区| 国产成人一区二区在线| www.久色| 日韩精品人妻中文字幕有码| 正在播放日韩精品| 在线观看精品自拍私拍| www.综合色| 亚洲国产精品精华素| 国产精品进线69影院| 91精品国产91久久综合桃花| 波多野结衣在线观看一区| 永久在线免费观看| 日韩成人在线电影| 日韩欧美999| 一区一区三区| 国风产精品一区二区| 日韩一区二区视频在线观看| 欧美日韩国内| 永久免费在线看片视频| 99视频免费观看蜜桃视频| 亚洲香蕉av在线一区二区三区| 成年人免费在线播放| 亚洲一卡二卡三卡四卡| 国产亚洲精品福利| 欧美孕妇孕交黑巨大网站| 国产日韩在线看| 秋霞av在线| 国产精品美女久久久久久久| 男人女人靠逼视频| 欧美精品自拍| 日韩在线中文字| 中文字幕亚洲欧美| 男人天堂亚洲天堂| 日本中文字幕免费在线观看| 中文在线手机av| 色久优优欧美色久优优| 亚洲第一偷拍网| 国内国产精品久久| 日本夜爽爽一二区| 欧美做a欧美| 日本久久精品视频| 97超碰国产精品女人人人爽| 九九九九九九精品| 国产日韩在线一区二区三区| 国精产品一品二品国精品69xx| 日韩理论电影中文字幕| 国产成人三级一区二区在线观看一| 91麻豆精品秘密| 国产成人精品综合久久久| 中文乱码免费一区二区| 亚洲成人精品久久久| 777午夜精品视频在线播放| 亚洲跨种族黑人xxx| 成人97精品毛片免费看| 日本视频一区二区在线观看| av漫画网站| 猫咪成人官网| 国产经典视频一区| 国产成a人亚洲| 97久久久精品综合88久久| 午夜视频在线看| 精品少妇爆乳无码av无码专区| www.日韩高清| aa视频在线免费观看| 国产资源在线观看入口av| 日韩精品电影网| 性做久久久久久久| 久久99性xxx老妇胖精品| 网址你懂得在线观看| 成人美女在线视频| 国内久久久精品| 欧美精品一区二区三区在线四季| 在线天堂视频| 日韩欧美国产电影| 在线观看黄色网| 国产性一乱一性一伧一色| 影音先锋在线国产| 88av在线视频| 九九在线精品视频| 日韩欧美黄色网址| 很黄很黄的网站免费的| 亚洲综合成人网| 国产成人亚洲精品无码h在线| 午夜国产不卡在线观看视频| 日韩av在线影院| 日韩片电影在线免费观看| www.爱久久| 国产成人精品一区二区三区在线观看| 久久发布国产伦子伦精品| 久久91精品国产91久久小草| 精品无码一区二区三区| 成人手机在线视频| 中文字幕一区二区三区四区五区人| 日本熟女毛茸茸| 国产98色在线| 成人网站免费观看| 国产不卡免费视频| 成人免费xx| 老司机精品福利视频| 亚洲新中文字幕| 电影一区二区在线观看| 在线视频国产日韩| 亚洲欧美综合精品久久成人| 91久久精品日日躁夜夜躁国产| 精品视频一区二区三区四区五区| 欧美性一区二区三区| sm一区二区三区| 草莓视频丝瓜在线观看丝瓜18| 亚洲天堂av网| 日韩欧美国产系列| 亚洲中文字幕无码av永久| 一区二区三区精| 亚洲黄色av网站| 天堂8在线天堂资源bt| 在线成人精品视频| 久久久久久免费网|