python中getopt()函数用法详解

 更新时间:2022年12月01日 08:33:41   作者:eliwang  
这篇文章主要介绍了python中getopt()函数用法,通过getopt模块中的getopt( )方法,我们可以获取和解析命令行传入的参数,需要的朋友可以参考下

通过getopt模块中的getopt( )方法,我们可以获取和解析命令行传入的参数

一、函数用法

  • getopt(args, shortopts, longopts=[ ])

    • args:固定写法sys.argv[1:]
    • shortopts:短参
      • 字符串类型,限制命令行可传入的短参名称(命令行可不传参,如果传参,必须是指定的参数名,否则会报错)
      • 参数名必须为单字符,前面使用单短横线(-)
      • 命令行写法:
        • -a  不带参数值形式
        • -b test_b  带参数值形式(中间空格可省略,个人推荐带上空格,更容易区分)
        • -c 'test c'  参数值含空格,需要使用引号
      • 按照上述命令行写法,shortopts的写法可以是:'ab:c:'
        • 如果带参数值,则需要在参数名后面带上':'
        • 各参数名先后顺序无所谓,比如'b:ac:'
    • longopts:长参
      • 数组类型,元素为字符串,限制命令行可传入的长参名称(命令行可不传参)
      • 参数名前使用双短横线(--)
      • 命令行写法:
        • --aa  不带参数值形式
        • --bb=test_bb  带参数值形式
        • --cc='test cc'  带参数值形式,参数值含空格,需要使用引号
      • 按上述命令行写法,longopts写法可以是:['aa', 'bb=', 'cc=']
        • 如果带参数值,则需要在参数名后面带上'='
        • 各参数名先后顺序无所谓

二、示例

代码

#! /usr/bin/env python
# -*- coding: utf-8 -*-

import sys
from getopt import getopt

opts, args = getopt(sys.argv[1:], 'ab:', ['aa', 'bb='])

# 解析出的参数名和值,格式:[(参数1,参数值1), (参数2,参数值2)...]
print(f'opts: {opts}')

# 未解析出来的参数值部分
print(f'args: {args}')

命令行

python main.py -a -b 'test short_b' --aa --bb=long_bb xxxx

输出:

opts: [('-a', ''), ('-b', 'test short_b'), ('--aa', ''), ('--bb', 'long_bb')]
args: ['xxxx']

对于没有参数值的a和aa参数,解析出的参数值都为空字符串'',由于bb参数的参数值long_bb和xxxx之间有空格,所以未解析出

命令行

python main.py -b=test_b

输出:

opts: [('-a', ''), ('-b', 'test short_b'), ('--aa', ''), ('--bb', 'long_bb')]
args: ['xxxx']

参数可传,也可省略,如果传,则必须是代码中所指定的

到此这篇关于python中getopt()函数用法的文章就介绍到这了,更多相关python getopt()函数用法内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • python3常用的数据清洗方法(小结)

    python3常用的数据清洗方法(小结)

    这篇文章主要介绍了python3常用的数据清洗方法(小结),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-10-10
  • Python将多个excel表格合并为一个表格

    Python将多个excel表格合并为一个表格

    这篇文章主要为大家详细介绍了Python将多个excel表格合并为一个表格的方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-01-01
  • pygame实现非图片按钮效果

    pygame实现非图片按钮效果

    这篇文章主要介绍了pygame实现非图片按钮效果,不使用图片制作,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-10-10
  • 10分钟快速入门Pandas库

    10分钟快速入门Pandas库

    pandas 是基于NumPy 的一种工具,该工具是为解决数据分析任务而创建的,这篇文章主要介绍了10分钟快速入门Pandas库,重点介绍pandas常见使用方法,结合实例代码介绍的非常详细,需要的朋友可以参考下
    2023-02-02
  • 一文带你深入了解Python中的二次移动平均法

    一文带你深入了解Python中的二次移动平均法

    二次移动平均法,也称为指数加权移动平均法,是一种用于平滑时间序列数据的算法。这篇文章主要通过示例来和大家聊聊二次移动平均法的使用,需要的可以了解一下
    2023-02-02
  • Django中使用Celery的方法示例

    Django中使用Celery的方法示例

    这篇文章主要介绍了Django中使用Celery的方法示例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-11-11
  • Python编码时应该注意的几个情况

    Python编码时应该注意的几个情况

    对于Python程序员,你需要注意一下本文所提到的这些事情。你也可以看看Zen of Python(Python之禅),这里面提到了一些注意事项,并配以示例,可以帮助你快速提高
    2013-03-03
  • 尝试用最短的Python代码来实现服务器和代理服务器

    尝试用最短的Python代码来实现服务器和代理服务器

    "人生苦短、我用Python",Python最大的特点便是代码简洁,得益于Python自带的wsgiref包和socket模块,这里我们将尝试用最短的Python代码来实现服务器和代理服务器:
    2016-06-06
  • python opencv判断图像是否为空的实例

    python opencv判断图像是否为空的实例

    今天小编就为大家分享一篇python opencv判断图像是否为空的实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-01-01
  • Python基于Logistic回归建模计算某银行在降低贷款拖欠率的数据示例

    Python基于Logistic回归建模计算某银行在降低贷款拖欠率的数据示例

    这篇文章主要介绍了Python基于Logistic回归建模计算某银行在降低贷款拖欠率的数据,结合实例形式分析了Python基于逻辑回归模型的数值运算相关操作技巧,需要的朋友可以参考下
    2019-01-01

最新评论