欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python的ArgumentParser使用及說明

 更新時間:2023年08月02日 15:47:14   作者:黃色摩托  
這篇文章主要介紹了python的ArgumentParser使用及說明,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教

python的ArgumentParser使用

ArgumentParser是python用來標(biāo)準(zhǔn)化處理sys.argv

#!/usr/bin/env python
# coding: utf8
from argparse import ArgumentParser
OPT_BOOK = {
    'dest': 'book',
    'nargs': '+',
    'help': 'Which book do you want study',
    'required': True
}
OPT_PAGE = {
    'dest': 'page',
    'nargs': '+',
    'help': 'Pages of book to study',
    'required': True
}
OPT_ITEM = {
    'dest': 'item',
    'nargs': '+',
    'help': 'Pages of book to study',
    'required': True
}
OPT_WORD = {
    'dest': 'word',
    'nargs': '+',
    'help': 'Pages of book to study',
    'required': True
}
def _create_parser(parser_factory):
    """ 創(chuàng)建二級命令
    """
    parser = parser_factory('project', help='Study project')
    parser.add_argument('-b', '--book', **OPT_BOOK)
    parser.add_argument('-p', '--page', **OPT_PAGE)
    parser.add_argument('-i', '--item', **OPT_ITEM)
    parser.add_argument('-w', '--word', **OPT_WORD)
    return parser
def create_argument_parser():
    """ 創(chuàng)建一級命令
    """
    parser = ArgumentParser(prog='study')
    subparsers = parser.add_subparsers()
    subparsers.dest = 'project'
    subparsers.required = True
    _create_parser(subparsers.add_parser)
    return parser

簡單的使用按照以上方式來做,用程序名構(gòu)造ArgumentParser(這里是study),隨意給一個父命令add_subparsers(這里是project),然后建立解析工廠parser_factory(這里是project和父命令同名),最后給一堆的參數(shù)輸入型命令add_argument(這里是book,page,item,word,可以用不定參字典,給予幫助信息或必傳等選項(xiàng))

這里是test方法:

#!/usr/bin/env python
# coding: utf8
import sys
from utils.logger import get_logger
from utils.commander import create_argument_parser
if __name__ == '__main__':
    parser = create_argument_parser()
    arguments = parser.parse_args(sys.argv[1:])
    get_logger().info(arguments.project)
    get_logger().info(arguments.book)
    get_logger().info(arguments.page)
    get_logger().info(arguments.item)
    get_logger().info(arguments.word)

這里是輸出:

[INFO]:2021-02-02 17:16:01,074:{TFSpleeter:project}
[INFO]:2021-02-02 17:16:01,074:{TFSpleeter:['book-a']}
[INFO]:2021-02-02 17:16:01,074:{TFSpleeter:['32']}
[INFO]:2021-02-02 17:16:01,074:{TFSpleeter:['what', 'is', 'item']}
[INFO]:2021-02-02 17:16:01,074:{TFSpleeter:['fuck']}

python對象屬性ArgumentParser,Namespace

1. ArgumengParser

1.1. 作用

分配屬性,可以從python執(zhí)行命令參數(shù)中獲取

1.2. 導(dǎo)包

# python
from argparse import ArgumentParser

1.3. 參數(shù)

ArgumentParser(prog=None)
  • prog:顯示的程序名,不填則默認(rèn)是文件名

1.4. 屬性

  • 1.4.1. add_argument(*args, **kwargs)

聲明創(chuàng)建屬性的規(guī)則

參數(shù)

  • 第一個參數(shù): 必填,鍵名,格式:"-a"或"–a"
  • dest: 非必填,參數(shù)名重置為
  • default: 非必填,默認(rèn)值
  • type: 非必填,參數(shù)類型
  • choices: 非必填,可選值,格式:列表,元組
  • required: 非必填,是否必填,默認(rèn)False
  • namespace: 非必填,分配屬性的對象
  • help: 非必填,說明文字

舉個栗子

# python
b = B()
parser = ArgumentParser()
parser.add_argument('--foo', dest='jjj', type=str, required=True)
parser.add_argument('-env', choices=['test', 'prod'])
  • 1.4.2. parse_args(args=None, namespace=None)

將參數(shù)轉(zhuǎn)為對象,并將屬性分配給命名空間

參數(shù)

  • args:非必填,賦值列表,必須一一對應(yīng)
  • namespace: 非必填,分配屬性的對象

舉個栗子

1.代碼行分配

# python
a = parser.parse_args(['--foo', 'werw', '-env', '234'])
print(a.env)
# 輸出 234
b = B()
parser.parse_args(['--foo', 'werw', '-env', '234'], namespace=b)
print(b.env)
# 輸出 234

2.啟動命令分配

# linux
python3 test.py --foo='www' -evn='234'

2. Namespace 命名空間

2.1. 作用

創(chuàng)建一個包含屬性的對象,返回該對象

2.2. 導(dǎo)包

# python
from argparse import Namespace

2.3. 用法

# python
a = Namespace(env='test', level=2)
print(a.evn)
# 輸出 test
print(a.level)
# 輸出 2

總結(jié)

以上為個人經(jīng)驗(yàn),希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

最新評論