Python命令行选项參数解析策略

概述

在Python的项目开发过程中,我们有时须要为程序提供一些能够通过命令行进行调用的接口。只是,并非直接使用 command + 当前文件 就ok的,我们须要对其设置可选的各种各样的操作类型。所以,这样的情况下我们就有必要对传入的參数进行解析操作。

以下就此问题提出几种不同的解决策略。希望于你故意。


版权说明

著作权归作者全部。

商业转载请联系作者获得授权,非商业转载请注明出处。

作者:Coding-Naga

发表日期: 2016年3月18日

链接:http://blog.csdn.net/lemon_tree12138/article/details/50912898

来源:CSDN

很多其它内容:分类 >> Thinking In Python


文件夹

  • 概述
  • 版权说明
  • 文件夹
  • 朴素字符串匹配方案
    • 分析
    • 长处
    • 缺点
  • getopt模块
    • 简单介绍
    • 实战用例
  • OptionParser模块
    • 简单介绍

      • parseradd_option參数说明
    • 实战用例
  • Ref

朴素字符串匹配方案

分析

事实上此方法能够非常直接地表达程序员们在逻辑这条路走了多远。

当然,这并没有包括不论什么的不敬。

这的确是一种方案,甚至能够说是一种算法。由于其直截了当。所以在程序开发初期,本人也是如此乐此不疲。

除了全然的一个一个的命令之外。我们还能够对參数进行json封装,这样就更加体贴了。

关于。这一点我想也不用多说什么的了。

还是留一些时间给后面的两种解决方式比較妥当。只是还是能够说说此方案的长处与缺点。

长处

  1. 针对不同的參数进行不同的处理,针对性强

缺点

  1. 由于其针对性太强,所以其复用性太差

getopt模块

简单介绍

此模块是python内置的一个模块。该模块是专门用来处理命令行參数的。

其基本使用格式例如以下:

opts, args = getopt.getopt(args, shortopts, longopts = [])

对于getopt()方法的第一个參数,就是我们通过命令行传入的參数。

只是这里也有一个值得注意的地方,我须要对參数列表进行切片处理。由于我们获得的第一个(args[0])命令行參数是当前文件名。这并非我们须要的。

对于getopt()的第二个參数,是shortopts。第三个參数,是longopts

shortopts比方:-h

longopts比方:–help

shortopts是以’-‘为前缀的,longopts是以”- -“为前缀的.

我们也能够单独使用短參数。基本使用格式例如以下:

opts, args = getopt.getopt(sys.argv[1:], "ld:")

实战用例

from __init__ import *

def usage():
    print ‘prama_config.py usage:‘
    print ‘-h, --help:      Print help message.‘
    print ‘-v, --version:   Print script version‘
    print ‘-o, --output:    Input an output verb‘
    print ‘-m, --message:   Send a message to someone.‘
    print ‘--foo:           Test option ‘
    print ‘--fre:           Another test option‘

def version():
    print ‘prama_config.py 1.0.1‘

def output(args):
    print ‘Hello, %s‘ % args

def message(sender, receiver, msg):
    print("{0} Send a message to {1}, content is \‘{2}\‘.".format(sender, receiver, msg))

def main(argv):
    try:
        opts, args = getopt.getopt(argv[1:], ‘hvom:‘, [‘help=‘, ‘message=‘, ‘foo=‘, ‘fre=‘])
    except getopt.GetoptError, err:
        print str(err)
        usage()
        sys.exit(2)
    for o, a in opts:
        if o in (‘-h‘, ‘--help‘):
            usage()
            sys.exit(1)
        elif o in (‘-v‘, ‘--version‘):
            version()
            sys.exit(0)
        elif o in (‘-o‘, ‘--output‘):
            output(a)
            sys.exit(0)
        elif o in (‘-m‘, ‘--message‘):
            message(a, args[0], args[1])
            sys.exit(0)
        else:
            print ‘unhandled option‘
            sys.exit(3)

if __name__ == ‘__main__‘:
    main(sys.argv)

OptionParser模块

简单介绍

前面说到getopt,只是getopt太小了,并且从代码的角度看。面向过程的嫌疑非常重。

相对getopt,OptionParser就显得比較专业级了。

OptionParser通过parser.add_option()加入选项參数。再通过parser.parse_args()进行解析參数选项。

整个过程非常面向对象

对于OptionParser另一个长处在于,我们不须要为OptionParser设置help的选项。help选项已经被内置到模块其中去了。

parser.add_option()參数说明

  1. action: action是parse_args() 方法的參数之中的一个,它指示 optparse 当解析到一个命令行參数时该怎样处理。actions 有一组固定的值可供选择,默认是’store ‘,表示将命令行參数值保存在 options 对象里。

    action的取值有store, store_true, store_false三个;

  2. dest: dest是存储的变量,命令行的运行命令将会保存到dest指定的值其中。

    比方,以下代码中的-p命令。就会被保存到dest=”pdcl”指定的options的pdcl变量中;

  3. default: 用于设置上面dest中保存变量的默认值。比方以下的代码中,我们就将默认值打成了False。

    那么,我们通过options.pdclp这个变量訪问到的值就是False;

  4. type: 用于指定dest中保存变量值的数据类型。

    默认的数据类型为string;

  5. help: 用于指定当前命令的提示信息。

实战用例

from optparse import OptionParser

parser = OptionParser()

parser.add_option(
    "-p", "--pdbk",
    action="store_true",  # 指示 optparse 当解析到一个命令行參数时该怎样处理
    dest="pdcl",  # 存储的变量
    default=False,
    help="write pdbk data to oracle db"
)

parser.add_option(
    "-z", "--zdbk",
    action="store_true",
    dest="zdcl",  # 存储的变量
    default=False,
    help="write zdbk data to oracle db"
)

parser.add_option(
    "-f", "--file",  # 操作指令
    action="store",
    dest="filename",  # 存储的变量
    type="string",  # 变量类型
    help="write report to FILE",  # 显示的帮助信息
    metavar="FILE"  # 存储变量的值
)

parser.add_option(
    "-q", "--quiet",
    action="store_false",
    dest="verbose",
    default=True,
    help="don‘t print status messages to stdout"
)

(options, args) = parser.parse_args()

if options.pdcl is True:
    print ‘pdcl is true‘
if options.zdcl is True:
    print ‘zdcl is true‘
if options.filename is not None:
    print("filename={0}".format(options.filename))
    print(args)

通过对上面三种參数解析策略的说明,能够看到这里使用OptionParser模块进行解析是最佳方式。


Ref


时间: 2024-08-25 14:01:33

Python命令行选项參数解析策略的相关文章

Python命令行选项参数解析策略

概述 在Python的项目开发过程中,我们有时需要为程序提供一些可以通过命令行进行调用的接口.不过,并不是直接使用 command + 当前文件 就ok的,我们需要对其设置可选的各种各样的操作类型.所以,这种情况下我们就有必要对传入的参数进行解析操作.下面就此问题提出几种不同的解决策略,希望于你有益. 版权说明 著作权归作者所有. 商业转载请联系作者获得授权,非商业转载请注明出处. 作者:Coding-Naga 发表日期: 2016年3月18日 链接:http://blog.csdn.net/l

argparse - 命令行选项与参数解析

argparse模块作为optparse的一个替代被添加到Python2.7.argparse的实现支持一些不易于添加到optparse以及要求向后不兼容API变化的特性,因此以一个新模块添加到标准库. 与optparse相比较 argparse的API类似于optparse,甚至在很多情况下通过更新所使用的类名和方法名,使用argparse作为一个简单的替代.然而,有些地方在添加新特性时不能保持直接兼容性. 你必须视情况决定是否升级已有的程序.如果你已编写了额外的代码以弥补optparse的局

python argparse模块解析命令行选项简单使用

argparse模块的解析命令行选项简单使用 util.py #!/usr/bin/env python # coding=utf-8 import argparse parser = argparse.ArgumentParser(prog="myprogram ",description="a test of argparse") parser.add_argument("-a",type=int,dest="start"

optparse 模块—— 命令行选项的解析器

15.5 optparse 模块--  命令行选项的解析器 注意:从2.7版本后不再使用:optparse模块不推荐使用,python不再更新该模块,后续的发展将推荐使用argparse模块. 支持python2.3及以上版本 optparse模块比旧的getopt模块具有更方便.更灵活.功能更强大的解析命令行选项的库.optparse使用一种更加声明式的命令行解析风格:你创建一个OptionParser实例,填充选项,并解析命令行.optparse允许用户指定选项,使用传统的GNU/POSIX

Python getopt模块处理命令行选项实例教程

分享下Python getopt模块处理命令行选项的一些例子. 在python编程中,getopt模块与shell中的getopt参数模块一样灵活而实用. getopt模块用于抽出命令行选项和参数,也就是sys.argv 命令行选项使得程序的参数更加灵活.支持短选项模式和长选项模式例如 python scriptname.py -f 'hello' --directory-prefix=/home -t --format 'a' 'b' import getopt, sys shortargs

命令行选项解析相关知识点

最近读源码的时候碰到命令行解析相关的知识点,比较模糊.摘取出来做个记录 1.最基本的main函数头 main(int argc,char *argv[ ]) 如果只输入程序名xxx,则argc=1,argv[0]指向输入的程序路径及名称./xxx;如果输入xxx para_1(程序名加一个参数),则argc=2,argv[0] 指向输入的程序路径及名称,argv[0]指向参数para_1字符串.以此类推,也就是char  *argv[]:argv 是一个指针数组,其元素个数是argc,存放的是指

命令行选项解析函数(C语言):getopt()和getopt_long()

上午在看源码项目 webbench 时,刚开始就被一个似乎挺陌生函数 getopt_long() 给卡住了,说实话这函数没怎么见过,自然不知道这哥们是干什么的.于是乎百度了一番,原来是处理命令行选项参数的,的确,正规点的大型程序一般第一步就是处理命令行参数的,接着才是主干程序.在百度和 man 的帮助下,找到了具体使用方法和解释,二话不说赶紧学习一下,并总结出文档记录一下. 平时在写程序时常常需要对命令行参数进行处理,因为参数少,自己解析就可以搞定:如果命令行个数比较多时,如果按照顺序一个一个定

安装loadrunner时出现”命令行选项语法错误键入命令 \?获得帮助“的解决方法

安装LR11 时,安装Microsoft Visual c++2005 sp1运行时组件,就会提示命令行选项语法错误,键入"命令/?"可获取帮肋信息1.进入loadrunner-11\Additional Components\IDE Add-Ins\MS Visual Studio .NET 2.安装:LRVS2005IDEAddInSetup.exe 2.再安装loadrunner

详解Top命令 输出命令行选项及代码

Linux中的top命令显示系统上正在运行的进程.它是系统管理员最重要的工具之一.被广泛用于监视服务器的负载.在本篇中,我们会探索top命令的细节.top命令是一个交互命令.在运行top的时候还可以运行很多命令.我们也会探索这些命令. (译注:不同发行版的top命令在各种细节有不同,如果发现不同时,请读你的帮助手册和命令内的帮助.) 1. Top 命令输出 首先,让我们了解一下输出.top命令会显示系统的很多信息.我们需要理解不同部分输出的意义:默认运行时,top命令会显示如下输出: 前几行水平