Maison > développement back-end > Tutoriel Python > Introduction détaillée à l'utilisation de docopt, l'outil d'analyse des paramètres de ligne de commande en Python

Introduction détaillée à l'utilisation de docopt, l'outil d'analyse des paramètres de ligne de commande en Python

高洛峰
Libérer: 2017-03-28 09:22:42
original
1937 Les gens l'ont consulté

docopt est un outil utilisé pour analyser les paramètres de ligne de commande. Lorsque vous souhaitez ajouter des paramètres à un programme Python, vous n'avez plus à vous en soucier. L'article suivant présente principalement les informations pertinentes de docopt, l'outil d'analyse des paramètres de ligne de commande en Python. L'introduction est très détaillée. Les amis qui en ont besoin peuvent y jeter un œil ci-dessous.

Préface

docopt est une bibliothèque open source. Il a été présenté en détail dans le README, et il est également accompagné de nombreux exemples d'apprentissage. Cet article traduit également le contenu du README...

La plus grande caractéristique de docopt est que vous n'avez pas. ne vous inquiétez pas de la façon d'analyser les paramètres de la ligne de commande, mais lorsque vous écrivez le format souhaité selon certaines règles, l'analyse est terminée.

installation de docopt

docopt a de nombreuses versions, chacune prenant en charge différents langages. Le docopt le plus simple prend en charge les scripts python, docopt prend en charge les scripts java. et docopts prend en charge les scripts shell (les exemples suivants utilisent principalement docopts comme exemple. Pour plus de détails, veuillez vous référer aux instructions docopt de github

Installation de docopt

Prenez Mac OS X). à titre d'exemple d'installation. Avant d'installer docopts, vous devez d'abord installer docopt. Il existe deux méthodes d'installation

Première méthode

La méthode la plus simple consiste à l'installer directement avec pip, pip install docopt==0.6.2

Certains Mac peuvent ne pas prendre en charge la commande pip directe. Vous devez d'abord installer pip

Méthode 2

Vous pouvez également télécharger le code source sur github (docopt est un open source). projet source), puis utilisez python setup.py install Install

Install docopts

Pour installer docopts, vous devez utiliser la méthode deux ci-dessus pour installer docopt. Téléchargez le code source sur GitHub, puis utilisez. python pour l'installer. L'adresse de téléchargement est

Une analyse simple de l'implémentation de docopt

Il existe un tel attribut en Python __doc__. Sa valeur est une chaîne, qui représente généralement les informations d'aide, et docopt en profite, remplace les informations d'aide par les instructions d'analyse des paramètres de ligne de commande, puis les analyse.

Prenons un exemple dans docopt pour illustrer :


"""Naval Fate.
Usage:
 naval_fate.py ship new <name>...
 naval_fate.py ship <name> move <x> <y> [--speed=<kn>]
 naval_fate.py ship shoot <x> <y>
 naval_fate.py mine (set|remove) <x> <y> [--moored | --drifting]
 naval_fate.py (-h | --help)
 naval_fate.py --version
Options:
 -h --help  Show this screen.
 --version  Show version.
 --speed=<kn> Speed in knots [default: 10].
 --moored  Moored (anchored) mine.
 --drifting Drifting mine.
"""
from docopt import docopt
if __name__ == &#39;__main__&#39;:
 arguments = docopt(__doc__, version=&#39;Naval Fate 2.0&#39;)
 print(arguments)
Copier après la connexion

Dans l'extrait de code ci-dessus, une grande information d'aide is Nos instructions d'analyse des paramètres de ligne de commande appellent la fonction docopt à l'entrée de la fonction pour l'analyse. La variable d'arguments renvoyée est une variable lexique, qui enregistre si l'option est sélectionnée, quelle est la valeur du paramètre et d'autres informations lorsque le programme est exécuté. commence à partir de la ligne de commande Au moment de l'exécution, nous apprenons les options et les informations sur les paramètres saisies par l'utilisateur en fonction des enregistrements de la variable arguments.

Alors, comment écrire les instructions d'analyse des paramètres de ligne de commande devient crucial. Les informations d'analyse de la ligne de commande contiennent deux parties, à savoir le format du modèle d'utilisation et le format de description des options.

Format du modèle d'utilisation (Format du modèle d'utilisation)

Le modèle d'utilisation commence par usage : et se termine par une ligne vide, comme indiqué dans le extrait de code ci-dessus, il décrit principalement le format lorsque les utilisateurs ajoutent des paramètres de ligne de commande, c'est-à-dire le format lorsqu'il est utilisé, et l'analyse est également effectuée selon ce format.

Chaque modèle d'utilisation contient les éléments suivants :

* Paramètres

Les paramètres doivent être en majuscules ou placés entre crochets <>.

* Options

Les options commencent par un tiret - ou -. Le format est -o lorsqu'il n'y a qu'une seule lettre et --output lorsqu'il y a plus d'une lettre. Dans le même temps, vous pouvez également combiner plusieurs options à une seule lettre. -ovi est équivalent à -o, -v, -i. Les options peuvent également avoir des paramètres. N'oubliez pas d'ajouter une description aux options à ce stade.

Voici la signification de certains identifiants utilisés dans le modèle d'utilisation. Leur utilisation correcte permet de mieux terminer la tâche d'analyse :

* []

représente les éléments facultatifs, les éléments entre crochets sont facultatifs

* ()

représente les éléments obligatoires, les éléments entre parenthèses Vous devez en avoir un, même si vous choisissez-en un parmi plusieurs.

* |

Éléments mutuellement exclusifs, un seul élément de part et d'autre de la ligne verticale peut rester

* ...

signifie que l'élément peut apparaître à plusieurs reprises et que le résultat final analysé est une liste

* [options]

Spécifiez des options spécifiques à accomplir une tâche spécifique.

Format de description de l'option

La description de l'option est également essentielle, surtout lorsque l'option a des paramètres et doit l'être Lorsqu'on lui attribue une valeur par défaut .

Il existe deux formats pour ajouter des paramètres aux options :


-o FILE --output-FILE  # 不使用逗号,使用 = 符号
-i <file>, --input <file> # 使用逗号,不使用 = 符号
Copier après la connexion

Pour ajouter une description pour une option, utilisez simplement deux espaces pour séparer l'option et la description. C'est tout.

Lors de l'ajout d'une valeur par défaut à une option, ajoutez-la simplement après la description de la sélection, le format est le suivant [par défaut : ]


--coefficient=K The K coefficient [default: 2.95]
--output=FILE Output file [default: test.txt]
--directory=DIR Some directory [default: ./]
Copier après la connexion

Si l'option peut être répétée, sa valeur [default: ...] sera une liste. Si elle ne peut pas être répétée, sa valeur sera une chaîne.

Utilisez

pour comprendre l'utilisation du format de modèle et du format de description d'option. Vous pouvez mieux le comprendre avec les exemples donnés.

L'étape suivante consiste à obtenir les informations d'entrée.

在前面提到arguments参数是一个字典类型,包含了用户输入的选项和参数信息,还是上面的代码段例子,假如我们从命令行运行的输入是


python3 test.py ship Guardian move 100 150 --speed=15
Copier après la connexion

那么打印arguments参数如下:


{&#39;--drifting&#39;: False,
 &#39;--help&#39;: False,
 &#39;--moored&#39;: False,
 &#39;--speed&#39;: &#39;15&#39;,
 &#39;--version&#39;: False,
 &#39;<name>&#39;: [&#39;Guardian&#39;],
 &#39;<x>&#39;: &#39;100&#39;,
 &#39;<y>&#39;: &#39;150&#39;,
 &#39;mine&#39;: False,
 &#39;move&#39;: True,
 &#39;new&#39;: False,
 &#39;remove&#39;: False,
 &#39;set&#39;: False,
 &#39;ship&#39;: True,
 &#39;shoot&#39;: False}
Copier après la connexion

从打印信息可以看到,对于选项,使用布尔型来表示用户是否输入了该选项,对于参数,则使用具体值来表述。

这样一来,程序就可以从arguments变量中得到下一步的操作了。若是用户什么参数都没输入,则打印Usage说明提示输入内容。

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal