- 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库进行结合就更好了。
		