大家好,又见面了,我是你们的朋友全栈君。
Flake8简介
转载自:http://www.malike.net.cn/blog/2013/10/23/flake8-tutorial/
| COMMENTS
Flake8包装了下列工具:
- PyFlakes:静态检查Python代码逻辑错误的工具。
- pep8: 静态检查PEP 8编码风格的工具。
- Ned Batchelder’s McCabe script:静态分析Python代码复杂度的工具。
它综合上述三者的功能,在简化操作的同时,还提供了扩展开发接口。
安装
这里仅介绍Ubuntu的安装方法,其他安装方法见Flake8官网。
- 添加ppa:cjohnston/flake8。Ubuntu 12.04、12.10和13.04官方源仅提供pep8的包,而该PPA不仅提供了最新的python-flake8包,还提供最新的pep8包。Ubuntu 13.10和14.04默认已经提供最新的pep8和python-flake8,所以可以跳过这一步。
1 2 3 | sudo add-apt-repository ppa:likemartinma/python sudo apt-get update sudo apt-get -y --force-yes dist-upgrade |
---|
- 安装python-flake8
1 | sudo apt-get install python-flake8 |
---|
使用
- 递归检查当前目录的所有Python文件:
1 | flake8 . |
---|
- 检查指定文件
1 | flake8 foo.py bar.py |
---|
- 通过setup.py检查工程的所有Python文件:
1 | python setup.py flake8 |
---|
为了保证其在其他环境中正确运行,需要将flake8增加到setup_requires中,例如:
1 2 3 4 5 6 7 8 | setup( name="project", packages=["project"], setup_requires=[ "flake8" ] ) |
---|
- 由于默认禁用代码条件复杂度检查,需要通过–max-complexity激活该功能:
1 | flake8 --max-complexity 12 . |
---|
该功能对于发现代码过度复杂非常有用,根据Thomas J. McCabe, Sr(Cyclomatic complexity的创造者)研究,代码复杂度不宜超过10,而Flake8官网建议值为12。
配置
- 用户相关的配置存在~/.config/flake8中,如:
1 2 | [flake8] max-complexity=12 |
---|
个人感觉除了代码复杂度因子(max-complexity)外,其他参数的默认值已经很好,基本不需要再作配置。
- 工程相关的设置,可以存放在工程顶级目录的tox.ini或setup.cfg,格式与用户相关的配置一致。
与Git整合
在.git/hooks目录中,创建Git的pre-commit钩子脚本,Flake8可以对每次提交的代码进行检查。该脚本如下:
1 2 3 4 5 6 7 8 9 10 | #!/usr/bin/python import sys from flake8.run import git_hook COMPLEXITY = 12 STRICT = True if __name__ == '__main__': sys.exit(git_hook(complexity=COMPLEXITY, strict=STRICT)) |
---|
若strict为True,任何warning都将阻挡提交。否则(或缺省),warning仅会被打印到标准输出。
与vim整合
这里仅介绍vim插件vim-flake8的安装和配置
- 安装vim插件pathogen:
1 2 3 | mkdir -p ~/.vim/autoload ~/.vim/bundle curl -Sso ~/.vim/autoload/pathogen.vim https://raw.github.com/tpope/vim-pathogen/master/autoload/pathogen.vim |
---|
- 添加下列配置至~/.vimrc中:
1 2 3 | execute pathogen#infect() syntax on filetype plugin indent on |
---|
- 安装vim-flake8:
1 2 | cd ~/.vim/bundle git clone git://github.com/nvie/vim-flake8.git |
---|
至此,当vim打开Python源码后,按F7就会执行Flake8对当前文件进行检查。
插件
Flake8相比pep8的优势在于其良好的扩展性,pep8 1.4.6尚未支持命名规范的检查,却已有人开发Flake8的插件pep8-naming来弥补这个缺陷。
pep8-naming处于早期开发阶段,尚无人为其制作deb包。我花时间做了deb包,并上传到我的ppa:likemartinma/python上。通过下述步骤可以轻松安装它:
1 2 3 4 | sudo add-apt-repository ppa:likemartinma/python sudo apt-get update sudo apt-get -y --force-yes dist-upgrade sudo apt-get install pep8-naming |
---|
由于Python部分核心库的函数命令存在“历史遗留”问题,与PEP 8并不保持完全一致,如xml.parsers.expat.xmlparser.StartElementHandler,这给pep8-naming带来一定的误报困扰。
解决的办法是这样的代码行追加 # noqa 的注释,从避免flake8发出类似warning。
存在的问题
由于pep8尚未支持docstring规范的检查,也没有相关Flake8的插件。目前仅能用pep257来完成docstring规范的检查。期待pep257早日衍生成Flake8的插件。
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/194221.html原文链接:https://javaforall.cn