亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定

Python | 一個快速實現CLI 應用程序的腳手架

標簽:
Python

今天跟大家分享一下如何快速实现一个Python CLI应用程序的脚手架,之所以会做这个是因为当时需要做一个运维的小工具希望用命令行的方式来使用,但是搜遍网上很多资料都没有系统讲解从开发、集成、发布、文档等一系列流程的文章。

工程结构


https://img1.sycdn.imooc.com//5d311d830001b52307281262.jpg

如上图,这就是一个比较规范的Python CLI应用项目了,下面一一讲下各文件的用途:

项目文档


这里我们用Sphinx来实现文档的自动生成,当然你要首先通过markdown和rst文件定义好文档的内容,然后进入docs目录执行 make html命令就可以在_build目录下生成对应的静态文件,如下图:

https://img1.sycdn.imooc.com//5d311d2300011e1607230364.jpg

具体Sphinx如何使用以及配置后面会单独文章讲解

主工程


这里讲几个需要注意的地方
1、日志的配置:
这里可以全局设置日志的一些输出级别和格式化方式

https://img1.sycdn.imooc.com//5d311d290001058e07190595.jpg

2、cli文件
这里通过click库来实现

https://img1.sycdn.imooc.com//5d311d2e0001c73f07170476.jpg

3、二进制文件打包

https://img1.sycdn.imooc.com//5d311d320001a49705120371.jpg

如上图,有时候我们的工程中会包含二进制文件,也就是非Python代码的文件,这时候如果还是像往常一样打包发布,安装的时候会发现无法找到此文件,所以需要在根目录的MANIFEST.in文件中加入

https://img1.sycdn.imooc.com//5d311d350001cc8b07230120.jpg

脚本


如下图,这里的make-release文件主要是用来自动控制版本的,如下图,通过Git 的提交记录了来作为项目的唯一版本号标识,再对init文件进行重新写入达到持续集成时版本号自增的目的。

https://img1.sycdn.imooc.com//5d311d390001a0e407190350.jpg

单元测试


test文件夹中存放的就是项目的单元测试文件了,这里就不细展开讲了,后面会具体讲讲如何跟Jenkins集成实现静态代码检查

setup


最重要的就是setup.py这个文件了,项目最后打包发布到pypi仓库主要的配置信息都在这里了,如下图:

https://img1.sycdn.imooc.com//5d311d3d0001ce4807340588.jpg

这个脚手架的项目地址:https://github.com/logan62334/python-cli-template



作者:Logan62334
链接:https://www.jianshu.com/p/5322d39f4272


點擊查看更多內容
TA 點贊

若覺得本文不錯,就分享一下吧!

評論

作者其他優質文章

正在加載中
  • 推薦
  • 評論
  • 收藏
  • 共同學習,寫下你的評論
感謝您的支持,我會繼續努力的~
掃碼打賞,你說多少就多少
贊賞金額會直接到老師賬戶
支付方式
打開微信掃一掃,即可進行掃碼打賞哦
今天注冊有機會得

100積分直接送

付費專欄免費學

大額優惠券免費領

立即參與 放棄機會
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號

舉報

0/150
提交
取消