Bootstrap

argparse模块

argparse 使用

简单示例

我们先来看一个简单示例。主要有三个步骤:

  • 创建 ArgumentParser() 对象
  • 调用 add_argument() 方法添加参数
  • 使用 parse_args() 解析添加的参数

示例:

1

2

3

4

5

6

7

8

9

# -*- coding: utf-8 -*-

 

import argparse

 

parser = argparse.ArgumentParser()

parser.add_argument('integer', type=int, help='display an integer')

args = parser.parse_args()

 

print(args.integer)

 将上面的代码保存为文件 argparse_usage.py,在终端运行,结果如下:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

$ python argparse_usage.py

usage: argparse_usage.py [-h] integer

argparse_usage.py: error: too few arguments

 

$ python argparse_usage.py abcd

usage: argparse_usage.py [-h] integer

argparse_usage.py: error: argument integer: invalid int value: 'abcd'

 

$ python argparse_usage.py -h

usage: argparse_usage.py [-h] integer

 

positional arguments:

  integer     display an integer

 

optional arguments:

  -h, --help  show this help message and exit

 

$ python argparse_usage.py 10

10

 

定位参数

上面的示例,其实就展示了定位参数的使用,我们再来看一个例子 - 计算一个数的平方:

1

2

3

4

5

6

7

8

# -*- coding: utf-8 -*-

 

import argparse

 

parser = argparse.ArgumentParser()

parser.add_argument("square", help="display a square of a given number", type=int)

args = parser.parse_args()     # 上面的定义的"square"其实是相当于一个变量了,所以后面必须制定其实什么类型

print(rgs.square**2)

 将上面的代码保存为文件 argparse_usage.py,在终端运行,结果如下:

1

2

$ python argparse_usage.py 9

81

可选参数

现在看下可选参数的用法,所谓可选参数,也就是命令行参数是可选的,废话少说,看下面例子:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

# -*- coding: utf-8 -*-

 

import argparse

 

parser = argparse.ArgumentParser()

 

parser.add_argument("--square", help="display a square of a given number", type=int)

parser.add_argument("--cubic", help="display a cubic of a given number", type=int)

 

args = parser.parse_args()

 

if args.square:

    print(args.square**2)

 

if args.cubic:

    print(args.cubic**3)

将上面的代码保存为文件 argparse_usage.py,在终端运行,结果如下:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

$ python argparse_usage.py --h

usage: argparse_usage.py [-h] [--square SQUARE] [--cubic CUBIC]

 

optional arguments:

  -h, --help       show this help message and exit

  --square SQUARE  display a square of a given number

  --cubic CUBIC    display a cubic of a given number

 

$ python argparse_usage.py --square 8

64

 

$ python argparse_usage.py --cubic 8

512

 

$ python argparse_usage.py 8

usage: argparse_usage.py [-h] [--square SQUARE] [--cubic CUBIC]

argparse_usage.py: error: unrecognized arguments: 8

 

$ python argparse_usage.py  # 没有输出</

;