Flake8_quakemaker Flake8简介

2022-09-30 10:57:09 浏览数 (1)

大家好,又见面了,我是你们的朋友全栈君。

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

0 人点赞