日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

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

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

瀏覽:45日期:2024-09-09 13:08:22

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

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

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

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

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

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

注意:

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

每一個自定義的管理命令本質(zhì)是一個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命令時,你將得到如下輸出結(jié)果:

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

現(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命令時,你將得到如下輸出結(jié)果:

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

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

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

實際應用場景

前面的案例過于簡單,我們現(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命令,你將得到如下輸出結(jié)果:

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

注意:真正發(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,這時只需要調(diào)用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管理命令的詳細內(nèi)容,更多關于django 自定義manage.py管理命令的資料請關注好吧啦網(wǎng)其它相關文章!

標簽: Django
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产精品一卡| 亚洲乱码一区| 国产精品www994| 国产日产一区| 欧美日韩夜夜| 中文字幕日韩亚洲| 亚洲精选久久| 日本aⅴ免费视频一区二区三区| 亚洲网址在线观看| 日韩欧美美女在线观看| 日本色综合中文字幕| 国产欧美丝祙| 免费亚洲婷婷| 日韩福利视频网| 激情五月综合网| 精品久久网站| 中文一区一区三区免费在线观| 亚洲精华国产欧美| 在线亚洲免费| 亚洲另类av| 99国产成+人+综合+亚洲欧美| 日韩视频在线一区二区三区 | 日本va欧美va瓶| 亚洲精品裸体| 欧美亚洲免费| 精品日韩在线| 久久精品免视看国产成人| 国产一区2区| 美女网站一区| 99热精品在线观看| 久久国产三级| 日韩欧美少妇| 久久国产福利| 精品久久久中文字幕| 国产视频一区在线观看一区免费| 亚洲二区精品| 久久男女视频| 国产精品第十页| 久久精品毛片| 天堂成人免费av电影一区| 日本综合字幕| 国产一区导航| 日韩精选在线| 精品99在线| 亚洲aa在线| 欧洲精品一区二区三区| 久久国产欧美| 天堂av在线一区| 蜜乳av另类精品一区二区| 老牛影视精品| 日本一区二区免费高清| 中文一区二区| 日韩午夜黄色| 亚洲成人精品| 少妇精品久久久| 激情欧美丁香| 国产高清亚洲| 国产一区二区精品福利地址| 久久理论电影| 中文字幕av亚洲精品一部二部 | 国产日韩在线观看视频| 色8久久久久| 日本欧美大码aⅴ在线播放| 视频一区免费在线观看| 蜜臀久久久久久久| 久久婷婷一区| 亚洲a级精品| 久久久久久久久99精品大| 一区在线观看| 国产91欧美| 国产精品尤物| 欧美另类中文字幕| 亚洲一区国产一区| 国产综合亚洲精品一区二| 7777精品| 久久蜜桃资源一区二区老牛| 在线天堂资源www在线污| 日韩一区电影| 日本免费久久| 免费精品视频最新在线| 日韩成人a**站| 最新中文字幕在线播放 | 欧美日韩精品一区二区三区视频| 国产乱人伦丫前精品视频| 蜜桃伊人久久| 日本成人手机在线| 久久久91麻豆精品国产一区| 亚洲综合电影| 亚洲一本视频| 日韩在线电影| 欧美激情三区| 亚洲免费资源| 91精品美女| 91精品国产福利在线观看麻豆| 日本在线成人| 精品视频在线一区二区在线| 97精品久久| 亚洲综合激情在线| 日本免费一区二区三区四区| 国产亚洲欧美日韩在线观看一区二区| 久久久久国产精品一区三寸| 欧美三级第一页| 精品国产美女a久久9999| 久久久久久久欧美精品| 91亚洲精品在看在线观看高清| 亚洲精品韩国| 麻豆精品久久久| 亚洲免费黄色| 免费看日韩精品| 日韩在线黄色| 亚洲精品护士| 国产成人精品一区二区三区视频| 亚洲午夜黄色| 精品91福利视频| 欧美日韩一视频区二区| 日韩一区二区三免费高清在线观看| 日本伊人午夜精品| 视频在线观看91| 欧美成人午夜| 久久精品天堂| 国产精品成久久久久| 国产农村妇女精品一二区| 亚洲3区在线| 蜜桃视频在线观看一区| 久久麻豆精品| 欧美成a人国产精品高清乱码在线观看片在线观看久 | 国产视频一区免费看| 久久国产精品亚洲77777| sm捆绑调教国产免费网站在线观看 | 亚洲精品成a人ⅴ香蕉片| 精品精品99| 美腿丝袜亚洲一区| 伊人久久视频| 日韩毛片视频| 精品视频国内| 国产成人精品三级高清久久91| 色狠狠一区二区三区| 国产一区二区三区日韩精品 | 在线天堂中文资源最新版| 国产日韩一区二区三免费高清 | 亚洲天堂成人| 日韩视频在线一区二区三区| 欧美aa国产视频| 成人在线网站| 蜜桃视频第一区免费观看| zzzwww在线看片免费| 国产精品13p| 欧美亚洲三区| 亚洲日产av中文字幕| 日韩av二区在线播放| 粉嫩av一区二区三区四区五区 | 日韩中文字幕一区二区高清99| 久久电影tv| 91亚洲人成网污www| 日韩和欧美一区二区三区| 亚洲日本在线观看视频| 欧美日韩亚洲一区在线观看| 亚洲综合激情在线| 欧美日韩99| 国产一区二区三区不卡av| 久久男人天堂| 亚洲男女av一区二区| 欧美99久久| 日韩午夜视频在线| 精品国产乱码久久久久久1区2匹| 日韩三区在线| 蜜桃视频在线观看一区| 欧美经典一区| 99精品在线观看| 亚洲免费一区二区| 日本va欧美va欧美va精品| 精品国产亚洲一区二区三区| 欧美不卡高清一区二区三区| 免费看欧美美女黄的网站| 国产精品15p| 91精品韩国| 蜜臀av在线播放一区二区三区 | 91精品视频一区二区| 韩国女主播一区二区三区| 日韩成人亚洲| 亚洲精品美女91| 丰满少妇一区| 日韩精品一二三| 欧美激情麻豆| 激情丁香综合| 青青伊人久久| 欧美日韩色图| 91精品在线免费视频| 欧美中文一区二区| 久久xxxx| 免费在线成人| 免费精品视频| 久久久久久婷| 蜜桃免费网站一区二区三区| 久久不见久久见中文字幕免费| 日韩av首页| 91免费精品国偷自产在线在线| 欧美精选视频一区二区| 日韩高清在线观看一区二区| 国产精品videossex|