- A+
Python命令行运行的解析库有多种,如:argarse、docopt、click、invoke等,其中Argarse为python内置标准库,使用较为频繁,但用起来也较为麻烦。下面折叠部分为几种模块的基本用法,如果有时间可以具体了解。今天要分享的是一个非常好用的命令行持续运行的库 cmdln,是在python内置模块cmd的基础上进一步封装的开源项目。
一、cmdln库的优点
1.cmdln是在cmd模块基础上的封装,使用上和cmd一样简单,将函数名添加前缀do_即可实现函数通过命令行运行;
2.实现了类似Tkinter的mainloop方法,能够通过命令行单次执行,或多次执行,保持会话持续在终端运行,有点类似于ipython编辑器;
3.cmdln提供了方面便的函数解析功能,将命令参数进行自动解析,不需要重新造轮子编写参数解析函数;
4.有时代码中实现的函数命令功能较多,若手动整理有多少函数功能就会非常麻烦,cmdln库提供了一种方便的集成帮助,直接将所有函数进行整理并形成命令列表,方便查看有哪些命令及如何使用。同时,对每一个函数也提供了帮助信息,如:需要怎样使用该命令,需要哪些参数,每个参数是什么作用,最后的返回结果是什么等。
二、cmdln的使用方法
在了解cmdln使用之前先初步了解一下cmd模块的方法介绍及使用案例:
(1)cmdloop():类似与Tkinter的mainloop,运行Cmd解析器;
(2)onecmd(str):读取输入,并进行处理,通常不需要重载该函数,而是使用更加具体的do_command来执行特定的命令;
(3)emptyline():当输入空行时调用该方法;
(4)default(line):当无法识别输入的command时调用该方法;
(5)completedefault(text,line,begidx,endidx):如果不存在针对的complete_*()方法,那么会调用该函数,该函数主要是用于tab补充,且只能在linux下使用。
(6)precmd(line):命令line解析之前被调用该方法;
(7)postcmd(stop,line):命令line解析之后被调用该方法;
(8)preloop():cmdloop()运行之前调用该方法;
(9)postloop():cmdloop()退出之后调用该方法;
(10)help_command():对command命令的说明,其中command为可变字符
- from?cmd?import?Cmd
- import?os
- class?Client(Cmd):
- ????u"""help
- ????这是doc
- ????"""
- ????prompt?=?'pyFun>'
- ????intro?=?'Welcom?to?pyFun!'
- ????def?__init(self):
- ????????Cmd.__init__(self)
- ????def?do_hello(self,?arg):
- ????????print('hello',?arg)
- ????def?do_exit(self,?arg):
- ????????print('Bye!')
- ????????return?True??#?返回True,直接输入exit命令将会退出
- ????def?preloop(self):
- ????????print("print(this?line?before?entering?the?loop")
- ????def?postloop(self):
- ????????#?print('Bye!')
- ????????print("print?this?line?after?leaving?the?loop")
- ????def?precmd(self,?line):
- ????????print("print(this?line?before?do?a?command")
- ????????return?Cmd.precmd(self,?line)
- ????def?postcmd(self,?stop,?line):
- ????????print("print(this?line?after?do?a?command")
- ????????return?Cmd.postcmd(self,?stop,?line)
- if?__name__?==?'__main__':
- ????try:
- ????????os.system('cls')
- ????????client?=?Client()
- ????????client.cmdloop()
- ????except:
- ????????exit()
cmdln也与之类似,包括了alias命令别称,option命令参数,命令持续运行svn.main(loop=LOOP_ALWAYS)等,同时输入help 命令名 则可以输出对应该条命令的说明文档,
内置的说明文档变量有如下几个:
"${name}" 工具名称
"${option_list}" 参数列表
"${command_list}" 命令列表
"${help_list}" 参数帮助列表
"${cmd_name}" 命名名称
"${cmd_usage}" 命令帮助信息
"${cmd_option_list}" 命令参数信息列表
- import?sys
- import?cmdln
- class?MySVN(cmdln.Cmdln):
- ????name?=?"svn"
- ????@cmdln.alias("stat",?"st")
- ????@cmdln.option("-u",?"--show-updates",?action="store_true",
- ??????????????????help="display?update?information")
- ????@cmdln.option("-v",?"--verbose",?action="store_true",
- ??????????????????help="print?extra?information")
- ????def?do_status(self,?subcmd,?opts,?*paths):
- ????????"""${cmd_name}:?print?the?status?of?working?copy?files?and?directories
- ????????${cmd_usage}
- ????????${cmd_option_list}
- ????????"""
- ????????print("'svn?%s'?opts:??%s"?%?(subcmd,?opts))
- ????????print("'svn?%s'?paths:?%s"?%?(subcmd,?paths))
- if?__name__?==?"__main__":
- ????svn?=?MySVN()
- ????sys.exit(svn.main())
三、cmdln项目打包
通过cmdln库建立的项目可以通过pyinstaller进行打包成独立的exe文件,这样可以直接将exe文件分发给其他人使用,需要先通过pip installer pyinstaller ?安装pyinstaller,然后用cmd命令打开项目所在的入口文件目录中,pyinstaller -F example.py 即可将其打包成命名行工具了。
四、其他说明
cmdln相对来说较好使用,能够像ipython那样保持命令行终端会话持续运行,但是关于参数解析及提示的功能还是较弱,不过总体能满足命令行打包后持续运行的需求,若能够将cmd与click库进行结合就更好了。
- 我的微信
- 这是我的微信扫一扫
-
- 我的微信公众号
- 我的微信公众号扫一扫
-




