Pylint一个可以检查Python代码错误,执行代码规范的工具。它还可以对代码风格提出建议。

官网:https://pylint.readthedocs.io

pip install pylint

默认情况,Pylint就已经随着Python安装好。在Python的scripts目录下。

找一段小程序试验一下Pylint,程序很简单。

[html] view plain copy
  1. #!/usr/bin/env python
  2. # encoding: utf-8
  3. '''
  4. Created on 2017年2月4日
  5. @author: Arthur Guo
  6. '''
  7. N = 10
  8. YHTriangle = []
  9. for i in range(N):  # 行
  10. YHTriangle.append([])
  11. if i == 0:
  12. YHTriangle[i].append(1) #第一行只有 1
  13. else:
  14. YHTriangle[i].append(1) #最左元素永远为 1
  15. YHTriangle[i].append(1) #最右元素永远为 1
  16. for j in range(1,i):    #中间元素
  17. if i <> 0 and i <> 1:
  18. YHTriangle[i].insert(j,YHTriangle[i-1][j-1] + YHTriangle[i-1][j])
  19. for i in range(N):
  20. print YHTriangle[i]

命令行运行pylint yanghui.py,结果看起来很冗长

[html] view plain copy
  1. c:\>c:\Python27\Scripts\pylint.exe d:\workspace\PyComm\src\Interviews\yanghui.py
  2. No config file found, using default configuration
  3. ************* Module Interviews.yanghui
  4. C: 19, 0: Exactly one space required after comma
  5. for j in range(1,i):    #中间元素
  6. ^ (bad-whitespace)
  7. C: 21, 0: Exactly one space required after comma
  8. YHTriangle[i].insert(j,YHTriangle[i-1][j-1] + YHTriangle[i-1][j]
  9. )
  10. ^ (bad-whitespace)
  11. C: 23, 0: Final newline missing (missing-final-newline)
  12. C: 11, 0: Invalid constant name "YHTriangle" (invalid-name)
  13. Report
  14. ======
  15. 13 statements analysed.
  16. Statistics by type
  17. ------------------
  18. +---------+-------+-----------+-----------+------------+---------+
  19. |type     |number |old number |difference |%documented |%badname |
  20. +=========+=======+===========+===========+============+=========+
  21. |module   |1      |1          |=          |100.00      |0.00     |
  22. +---------+-------+-----------+-----------+------------+---------+
  23. |class    |0      |0          |=          |0           |0        |
  24. +---------+-------+-----------+-----------+------------+---------+
  25. |method   |0      |0          |=          |0           |0        |
  26. +---------+-------+-----------+-----------+------------+---------+
  27. |function |0      |0          |=          |0           |0        |
  28. +---------+-------+-----------+-----------+------------+---------+
  29. Raw metrics
  30. -----------
  31. +----------+-------+------+---------+-----------+
  32. |type      |number |%     |previous |difference |
  33. +==========+=======+======+=========+===========+
  34. |code      |15     |62.50 |15       |=          |
  35. +----------+-------+------+---------+-----------+
  36. |docstring |5      |20.83 |5        |=          |
  37. +----------+-------+------+---------+-----------+
  38. |comment   |2      |8.33  |17       |-15.00     |
  39. +----------+-------+------+---------+-----------+
  40. |empty     |2      |8.33  |3        |-1.00      |
  41. +----------+-------+------+---------+-----------+
  42. Duplication
  43. -----------
  44. +-------------------------+------+---------+-----------+
  45. |                         |now   |previous |difference |
  46. +=========================+======+=========+===========+
  47. |nb duplicated lines      |0     |0        |=          |
  48. +-------------------------+------+---------+-----------+
  49. |percent duplicated lines |0.000 |0.000    |=          |
  50. +-------------------------+------+---------+-----------+
  51. Messages by category
  52. --------------------
  53. +-----------+-------+---------+-----------+
  54. |type       |number |previous |difference |
  55. +===========+=======+=========+===========+
  56. |convention |4      |6        |-2.00      |
  57. +-----------+-------+---------+-----------+
  58. |refactor   |0      |0        |=          |
  59. +-----------+-------+---------+-----------+
  60. |warning    |0      |0        |=          |
  61. +-----------+-------+---------+-----------+
  62. |error      |0      |0        |=          |
  63. +-----------+-------+---------+-----------+
  64. Messages
  65. --------
  66. +----------------------+------------+
  67. |message id            |occurrences |
  68. +======================+============+
  69. |bad-whitespace        |2           |
  70. +----------------------+------------+
  71. |missing-final-newline |1           |
  72. +----------------------+------------+
  73. |invalid-name          |1           |
  74. +----------------------+------------+
  75. Global evaluation
  76. -----------------
  77. Your code has been rated at 6.92/10 (previous run: 5.38/10, +1.54)

‘’‘’Report

=======‘’‘’以上是Pylint对程序的建议,以下都是报告内容。多数时候,我们其实并不想看那么冗长的报告。这时候,体贴的Pylint就让我们屏蔽掉它们。

加上参数 --reports=n 或者更简单写成 -rn 就好了。再看检查结果:

[html] view plain copy
  1. c:\>c:\Python27\Scripts\pylint.exe --reports=n d:\workspace\PyComm\src\Interview
  2. s\yanghui.py
  3. No config file found, using default configuration
  4. ************* Module Interviews.yanghui
  5. C: 19, 0: Exactly one space required after comma
  6. for j in range(1,i):    #中间元素
  7. ^ (bad-whitespace)
  8. C: 21, 0: Exactly one space required after comma
  9. YHTriangle[i].insert(j,YHTriangle[i-1][j-1] + YHTriangle[i-1][j]
  10. )
  11. ^ (bad-whitespace)
  12. C: 23, 0: Final newline missing (missing-final-newline)
  13. C: 11, 0: Invalid constant name "YHTriangle" (invalid-name)

建议分三种:“bad-whitespace”, "missing-final-newline", "invalid-name".

前两个好说,加空格,加空行。但是下面这个怎么破?

[html] view plain copy
  1. C: 11, 0: Invalid constant name "YHTriangle" (invalid-name)

命名不规范?认为是个constant值? 其实可以把这类问题忽略掉。

“Invalid constant name” 错误号是 C0103,所以加上 --disable=C0103即可。

[html] view plain copy
  1. c:\>c:\Python27\Scripts\pylint.exe --reports=n --disable=c0103 d:\workspace\PyCo
  2. mm\src\Interviews\yanghui.py
  3. No config file found, using default configuration

没输出就是说名没问题了。

当然,还有更多的参数可以供选择。

=======================华丽丽的分割线===============================

平时写Python,我们几乎都不直接用命令行,而是用集成的IDE工具。比如猫哥常用的PyCharm。

Pylint官方文档提了可以支持PyCharm不过太简略了。

实际操作是这样的:

进入PyCharm,从菜单栏,依次进入: File -> Settings -> Tools -> External Tools。

“+”,进行添加。需要填写的部分分别是:“Name”,“Tool Settings -> Programs”、“Tool Settings -> Parameters”、“Tool Settings -> Working directory”。

注意:

“Parameters”里其它参数不管怎么写,必须在最后加上$FilePath$,“Working directory”里必须写 $FileDir

另外,需要再添加“Output Filter”,在上图中间靠右。填写内容的“Regular expression to match output”,必须是:$FILE_PATH$:$LINE$: 最后那个是冒号。

配置完毕,选择一个Python程序,右键点击,快捷菜单中会有“Extensions Tools -> Pylint”,点击运行即可。输出结果在执行程序结果的窗口(IDE下半部分)。

如果看到返回值为0,说明程序没问题了。

[html] view plain copy
  1. C:\Python27\Scripts\pylint.exe --reports=n --disable=C0103 D:\PyCharmSpace\test1\test1\hello.py
  2. No config file found, using default configuration
  3. Process finished with exit code 0

转载于:https://www.cnblogs.com/mhc-fly/p/7857620.html

用Pylint规范化Python代码,附PyCharm配置相关推荐

  1. JetBrains PyCharm 配置pylint(Python代码审阅工具)教程

    代码规范的重要性 一.规范的代码可以促进团队开发 二.规范的代码可以减少人力资源投入 三.规范的代码可以降低维护成本 四.规范的代码有助于代码审阅(说白了别人看着舒服,也能看懂) Pylint 是什么 ...

  2. 使用Pylint进行Python代码规范检查

    在上一篇中讲了autopep8的应用<使用aotupep8自动批量调整代码以符合PEP-8规范>,有时候只需要检查并提示,并不希望"自动修改",这个时候就该Pylint ...

  3. 使用 pylint 检测python代码质量(sonar-scanner调用pylint,然后数据交给sonar服务器)

    python 代码质量检查 直接使用 sonar-scanner 调用 pylint插件扫描生成 质量分析文件 pylint 官网地址:https://www.pylint.org/ 安装 sonar ...

  4. vscode python第三方库检测_VSCode中使用Pylint检查python代码

    为什么使用lint 在日常开发中,不同开发人员会写下不同风格的代码,导致代码可维护性变差,为了解决风格不一致问题,我们可以制定代码规范,让开发人员都遵守同样的规范编写代码.在开发过程中,部分代码存在质 ...

  5. VSCode中使用Pylint检查python代码

    为什么使用lint 在日常开发中,不同开发人员会写下不同风格的代码,导致代码可维护性变差,为了解决风格不一致问题,我们可以制定代码规范,让开发人员都遵守同样的规范编写代码.在开发过程中,部分代码存在质 ...

  6. python代码修改nginx配置_生产环境部署python代码(django+uwsgi+nginx)

    基础环境不做介绍,在django开发web项目完成后,一直使用django自带的服务器进行调试: python manage.py runserver 0.0.0.0:8080 这个服务器在开发时使用 ...

  7. Python代码在Pycharm中不起作用,但在Jupiter Notebook中执行良好

    代码 import requests from apscheduler.schedulers.background import BackgroundScheduler from datetime i ...

  8. vim配置python代码提示,VIM配置成Python IDE

    一.~/.vimrc 文件内容: set nocompatible              " required filetype off                  " ...

  9. python代码编辑器PyCharm快捷键补充

    个人觉得特别有用的: 替换:Ctrl+R 删除当前行 CTRY Y: 复制当前行:Ctrl+D ALT F7: 查找哪些地方使用了选中的方法. ALT UP: 移到上一个方法 ALT DOWN: 移到 ...

  10. Python3 pylint详解 (规范python代码风格)

    Pylint简介 Pylint 是一个 Python 代码分析工具,它分析 Python 代码中的错误,查找不符合代码风格标准(Pylint 默认使用的代码风格是 PEP 8,具体信息,请参阅参考资料 ...

最新文章

  1. java中ajax的用途_java Ajax的应用
  2. R语言作加权最小二乘_超越谷歌BERT!依图预训练语言理解模型入选NeurIPS
  3. 【fiddler抓包修改订单金额】
  4. win10user文件夹迁移_Win10纯净版下迁移用户文件的技巧
  5. openpose handpose 人体关键点识别 关键点检测
  6. Asp.Net Core 鉴权授权
  7. 小程序配置服务器域名不生效问题
  8. 如何实现rsync远程同步和inotify实时同步
  9. L1-021 重要的话说三遍 (5分)(C语言)
  10. 网络压线钳的实验报告_RJ45网线制作实验报告
  11. Java 获取访问者的IP地址
  12. css创建鼠标悬停下拉菜单样式
  13. [leetcode]378. 有序矩阵中第 K 小的元素
  14. github vue 高星项目
  15. 03 计算(a+b)/c的值
  16. Cisco交换机端口假死(err-disable)解决方法
  17. 淘宝限制词维护+小技巧,优化限制词,降低被投诉概率!
  18. 浅谈电力电子中的双脉冲测试
  19. Translatium for Mac 8.2.1 Google翻译 实时翻译 破解版下载
  20. 虾米音乐关停,QQ音乐、网易云上线虾米歌单迁移功能

热门文章

  1. 设计一个Enum Class
  2. 零顶会进大厂算法岗的正确姿势(干货总结)
  3. 互联网核心应用(搜索/推荐/广告)算法峰会
  4. TF2.0—tf.keras.losses.BinaryCrossentropy
  5. 机器学习基础算法18- 鸢尾花数据集分类-随机森林
  6. 梯度消失与梯度爆炸原因剖析
  7. key没有引号的字符串如何转json变为字典格式
  8. 如何在AI工程实践中选择合适的算法?
  9. Spring数据库事务典型错误用法剖析
  10. 书单丨被强化学习一次次伤害?本书单带你一步步入门!