我需要分析我输入的所有签名。 例如,我的输入可以是:
$ python script.py -i 4:64+0:0:1460:mss*20,7:mss,sok,ts,nop,ws:df:0
我想在:
和,
分割此输入,以便最终得到一个如下所示的列表:
['4', '64', '0', '1460', 'mss*20', '7', 'mss', 'sok', 'ts', 'nop', 'ws', 'df', '0']
然后我可以做一个循环或索引来分析我的项目的位置。
当我使用函数input()
和re.split()
时,我的程序可以正常工作。
但不是当我想在optparse
的论据中加入我的签名时。
如果有人可以帮助我那会很好,谢谢你的帮助。
答案 0 :(得分:1)
我认为这很简单。神奇的是字符串函数:replace
和split
。函数split
将给定分隔符的字符串拆分到列表中。但是你不能在解析的字符串中使用任何空格,因为argparse
会认为它是其他命令行参数。
以下是script.py
#!/usr/bin/env python
# -*- coding: UTF-8 -*
import argparse
DESCRIPTION=u"My parser"
def InitParser():
parser = argparse.ArgumentParser(DESCRIPTION)
parser.add_argument(
'-i', '--input',
help=u"Parameter splitted by comma or column"
)
return parser
def main():
parser = InitParser()
args = parser.parse_args()
print "Parser args=", args
print
if args.input:
lst = args.input.replace(':',',').split(',')
print "Splited -i argument:"
print(lst)
else:
print "Missing -i argument"
return
if __name__ == "__main__":
main()
节目输出:
C:\temp\tem>script.py -i 4:64+0:0:1460:mss*20,7:mss,sok,ts,nop,ws:df:0
Parser args= Namespace(input='4:64+0:0:1460:mss*20,7:mss,sok,ts,nop,ws:df:0')
Splited -i argument:
['4', '64+0', '0', '1460', 'mss*20', '7', 'mss', 'sok', 'ts', 'nop', 'ws', 'df', '0']