【问题标题】:How to make a Django custom management command argument not required?如何使 Django 自定义管理命令参数不需要?
【发布时间】:2016-06-08 16:32:41
【问题描述】:

我正在尝试在 django 中编写一个自定义管理命令,如下所示-

class Command(BaseCommand):

    def add_arguments(self, parser):
        parser.add_argument('delay', type=int)

    def handle(self, *args, **options):
        delay = options.get('delay', None)
        print delay

现在当我运行python manage.py mycommand 12 时,它会在控制台上打印 12。这很好。

现在,如果我尝试运行python manage.py mycommand,那么我想要它,该命令默认在控制台上打印 21。但它给了我这样的东西-

usage: manage.py mycommand [-h] [--version]
                           [-v {0,1,2,3}]
                           [--settings SETTINGS]
                           [--pythonpath PYTHONPATH]
                           [--traceback]
                           [--no-color]
                           delay

那么现在,如果没有给出值,我应该如何使命令参数“不需要”并取默认值?

【问题讨论】:

  • 您不想将这个delay = options.get('delay', None) 更改为这个delay = options.get('delay', 21) 来处理默认值吗?只是猜测。

标签: python django command


【解决方案1】:

您可以对可选的关键字参数使用破折号语法:

class Command(BaseCommand):

    def add_arguments(self, parser):
        parser.add_argument("-d", "--delay", type=int)

    def handle(self, *args, **options):
        delay = options["delay"] if options["delay"] else 21
        print(delay)

用途:

$ python manage.py mycommand -d 4
4
$ python manage.py mycommand --delay 4
4
$ python manage.py mycommand
21

文档:

https://docs.djangoproject.com/en/2.2/howto/custom-management-commands/#s-accepting-optional-arguments

简单解释:

https://simpleisbetterthancomplex.com/tutorial/2018/08/27/how-to-create-custom-django-management-commands.html#handling-arguments

【讨论】:

  • 这不起作用,因为您不知道用户输入的是 21 还是默认为 21。
  • @noone392 这不是真的,您可以通过检查if options["delay"] 轻松检查它是否默认。我的示例是具体的,当options["delay"] 为假时将值设置为 21,这对应于未传递的参数,因此我们应该使用默认值。
【解决方案2】:

documentation 中的一个食谱建议:

对于 nargs 等于 ?* 的位置参数,当不存在命令行参数时使用 default 值。

所以下面应该可以解决问题(如果提供,它将返回值,否则返回默认值):

parser.add_argument('delay', type=int, nargs='?', default=21)

用法:

$ ./manage.py mycommand
21
$ ./manage.py mycommand 4
4

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2016-03-28
    • 1970-01-01
    • 1970-01-01
    • 2019-09-24
    • 2018-06-19
    • 2015-07-26
    • 2017-11-25
    相关资源
    最近更新 更多