argparse 命令含参数模块

argparse是python的一个命令行参数模块,可以解析命令行参数,生成帮助等。

你可以这样使用它:

  1. #!/usr/bin/python
  2. from argparse import ArgumentParser
  3. p = ArgumentParser(usage='it is usage tip', description='this is a test')
  4. p.add_argument('--one', default=1, type=int, help='the first argument')
  5. p.add_argument('--two, default=2, type=int, help='the second argument')
  6. p.add_argument('--docs-dir, default="./", help='document directory')
  7. args = p.parse_args()
  8. #可以打印出来查看
  9. print args
  10. #打印某一个参数
  11. print args.one
  12. print args.docs_dir   #经过parse_args()函数后参数名称去掉了前面的"--",所有的"-"转换为"_"

这个文件的名称叫做test.py , 你可以这样运行它:

./test.py

想要查看是否有哪些参数可以:

./test.py --help  或者  ./test.py -h

会打印出以下信息:

  1. usage: it is usage tip
  2. this is a test
  3. optional arguments:
  4. -h, --help  show this help message and exit
  5. --one ONE   the first argument
  6. --two TWO   the second argument
  7. --docs-dir DOCS_DIR   document directory

然后就可以带参数运行程序:

./test.py --one 10 --two 20 --docs-dir /opt/docs/

但是在这种情况下:“如果运行程序时带了一个不认识的参数”,就会报错:

./test.py --p 235

  1. usage: it is usage tip
  2. test.py: error: unrecognized arguments: ./test.py --p 235

有时我们不希望这样,我们的需求是:只提取有用的参数,不认识的参数丢弃但并不需要报错".

这时程序可以这样写:

  1. #!/usr/bin/python
  2. import sys
  3. from argparse import ArgumentParser
  4. p = ArgumentParser(usage='it is usage tip', description='this is a test')
  5. p.add_argument('--one', default=1, type=int, help='the first argument')
  6. p.add_argument('--two, default=2, type=int, help='the second argument')
  7. p.add_argument('--docs-dir, default="./", help='document directory')
  8. # 这个函数将认识的和不认识的参数分开放进2个变量中
  9. args, remaining = p.parse_known_args(sys.argv)
  10. #可以打印出来查看
  11. print args
  12. print remaining

再次运行程序:

./test.py --p 235

这个时候就会打印出:

  1. Namespace(docs_dir='./', one=1, two=2)
  2. ['./test.py', '--p', '235']
上一篇:相等(==)、严格相等(===)、NaN、null、undefined、空和0


下一篇:oracle中Blob、Clob、Varchar之间的互相转换