使用vscode开发Python程序:代码静态检查工具pylint及代码格式化工具yapf的配置使用

准备工作

  1. 安装Python和pip工具,使用pip安装pylint和yapf: pip install pylint yapf
  2. 下载安装vscode:https://code.visualstudio.com/
  3. 打开vscode,点击左侧 扩展 图标按钮,点击 更多 选择 显示常用的扩展 ,选择并安装插件 Python (Microsoft官方发布),安装完成后点击 重新加载 即可重启vscode并激活 Python 插件

代码静态检查工具:pylint

默认设置

在vscode中依次点击 文件 -> 首选项 -> 设置 打开设置文件 settings.json(编辑器标签标题显示 User Settings ),vscode会自动分左右两栏显示,其中左栏是 默认用户设置 (已锁定为只读) ,右栏是 用户设置 ,用户写在右栏的自定义设置会覆盖掉左栏相应的默认设置。

settings.json 页面上方搜索栏内输入 python.linting 即可快速定位与Python代码静态检查工具相关的设置内容。激活 Python 插件后,默认设置已包含以下内容:

  // 默认对Python文件进行静态检查
  "python.linting.enabled": true,

  // 默认在Python文件保存时进行静态检查
  "python.linting.lintOnSave": true,

  // 默认使用pylint对Python文件进行静态检查
  "python.linting.pylintEnabled": true,

一般情况下直接采用以上默认设置即可启用pylint。当Python文件保存时,vscode会调用pylint执行静态检查,如检查发现问题则会以错误、警告或信息等形式显示在vscode下方的问题页面,同时在文本编辑器中以波浪线形式标示问题代码。

自定义设置:自定义pylint规则选项

以上默认设置的一个问题在于禁用了大部分pylint检查项目,导致pylint检查显示出的问题较少,对于某些简单的Python文件,pylint检查甚至不会显示出任何问题,仿佛pylint没有被实际调用一样。这是由于 Python 插件在 2018.1.0 (Jan. 2018) 版本更新中引入了一项默认设置:

  // 静态检查时是否使用pylint的最小规则集(minimal set of rules)
  "python.linting.pylintUseMinimalCheckers": true

这一默认设置等价于以下pylint选项

--disable=all  --enable=F,E,unreachable,duplicate-key,unnecessary-semicolon,global-variable-not-assigned,unused-variable,binary-op-exception,bad-format-string,anomalous-backslash-in-string,bad-open-mode

不难看出,这样的默认设置直接禁用了所有的规范(Convertion,C )和重构(Refactor,R )类规则,只保留了致命错误(Fatal,F )、错误(Error,E )和少数几个警告(Warning,W )类规则,因此pylint检查显示出的问题数量大幅减少。

自定义pylint规则选项:

  • 如果希望直接应用所有pylint检查规则,则可以简单将 "python.linting.pylintUseMinimalCheckers" 的值修改为 false

  • 如果只希望应用部分pylint检查规则或者需要使用pylint某些选项,则可在 settings.json 中找到以下默认设置:

    // pylint选项,每个选项都是数组中的一个字符串元素
    "python.linting.pylintArgs": []

    在数组 [] 中加入所需的pylint选项即可,例如

    // pylint选项,以逗号分隔的字符串元素
    "python.linting.pylintArgs": [
        "--disable=W0402,R0201,C0304", 
        "--extension-pkg-whitelist=numpy"
    ]

    此时 "python.linting.pylintUseMinimalCheckers" 的值将自动被覆盖为 false,不用再手动修改。

其它代码静态检查工具:flake8、mypy、pydocstyle、pep8、prospector、pylama

除pylint外,vscode的 Python 插件还支持flake8、mypy、pydocstyle、pep8、prospector、pylama等代码静态检查工具,但默认情况下不使用这些工具,仅使用pylint:

  // 默认不使用flake8对Python文件进行静态检查
  "python.linting.flake8Enabled": false,

  // 默认不使用mypy对Python文件进行静态检查
  "python.linting.mypyEnabled": false,

  // 默认不使用pep8对Python文件进行静态检查
  "python.linting.pep8Enabled": false,

  // 默认不使用prospector对Python文件进行静态检查
  "python.linting.prospectorEnabled": false,

  // 默认不使用pydocstyle对Python文件进行静态检查
  "python.linting.pydocstyleEnabled": false,

  // 默认不使用pylama对Python文件进行静态检查
  "python.linting.pylamaEnabled": false,

  // 默认使用pylint对Python文件进行静态检查
  "python.linting.pylintEnabled": true

如需使用某工具,只需要将上方对应的 "python.linting.xxxEnabled" 改为 true 即可(需要先用 pip 安装对应工具)。vscode可以同时调用多种工具进行代码静态检查,其输出互相独立,因此同一问题可能会被不同工具重复输出多次。

以上工具规则选项的自定义方法与pylint类似,找到并修改以下设置即可:

  // xxx选项,以逗号分隔的字符串元素
  "python.linting.xxxArgs": []

代码格式化工具:yapf

settings.json 页面上方搜索栏内输入 python.formatting 即可快速定位与Python代码格式化工具相关的设置内容。激活 Python 插件后,默认设置已包含以下内容:

  // Python代码格式化工具,可选'autopep8'、'black'或'yapf'.
  "python.formatting.provider": "autopep8",

Python 插件默认的代码格式化工具是autopep8,也可以使用black或yapf。推荐使用Google开发的yapf:

  • 首先,安装yapf:pip install yapf

  • 其次,将上面 "python.formatting.provider" 的值改为 "yapf"

  • 最后,如需自定义yapf选项,则可找到 ""python.formatting.yapfArgs": []" 并在数组 [] 中加入所需选项,例如

    // yapf选项,以逗号分隔的字符串元素
    "python.formatting.yapfArgs": [
       "--style", "{based_on_style: chromium, indent_width: 4}"
    ]

以上安装配置完成后,在Python代码编辑界面按 F1Ctrl + Shift + P 打开命令面板,输入 Format Document 即可调用yapf进行格式化,也可以在代码编辑页面使用默认快捷键直接调用yapf:Ctrl + Shift + ILinux系统)、Shift + Alt + FWindows系统)或 ⇧(Shift) + ⌥(Option) + FMac系统)。

除以上手动调用yapf以外,yapf也可以像pylint那样在文件保存甚至是代码段粘贴时自动调用,与之相关的设置是

  // 控制编辑器是否应自动设置粘贴内容的格式。格式化程序必须可用并且能设置文档中某一范围的格式。
  "editor.formatOnPaste": false,

  // 保存时设置文件的格式。格式化程序必须可用,不能自动保存文件,并且不能关闭编辑器。
  "editor.formatOnSave": false,

  // 在保存时格式化操作的超时时间。为 formatOnSave 命令指定时间限制 (单位: 毫秒)。运行超过设定时间的命令将被取消。
  "editor.formatOnSaveTimeout": 750,

可以看出这些设置属于 editor ,不是 Python 专属设置,因此这些设置会影响所有配置有格式化工具的语言文件。"editor.formatOnPaste""editor.formatOnSave" 默认均为 false ,主要是为了避免频繁自动调用格式化工具对编辑工作产生干扰,如确实需要可以将其改为 true

常见报错

vscode报错:Linter pylint is not installed 或者 Path to the pylint linter is invalid

  • 首先,确认pylint已正确安装,可打开命令行/终端测试 pip show pylint 能否正确打印模块信息。

  • 其次,在vscode中打开设置文件 settings.json ,找到以下默认设置:

    // pylint的默认调用路径
    "python.linting.pylintPath": "pylint",

    其中 "python.linting.pylintPath" 给定pylint的调用路径,正常情况下此路径应该已包含在系统环境变量中,因此采用以上默认设置即可直接调用pylint(可打开命令行/终端测试 pylint --version 能否正确打印版本信息);如无法直接调用pylint,则应将此项设置修改为pylint的正确调用路径。

  • 最后,如果电脑上同时安装有Python2和Python3,则需要注意区分和引导vscode采用哪个Python版本。对于同时安装有Python2和Python3的Linux系统,若只需开发Python3程序,并只对Python3进行代码静态检查(请确认已正确安装适配Python3版本的pylint模块),则可打开设置文件 settings.json ,找到以下默认设置:

    // 默认Python路径
    "python.pythonPath": "python",

    "python.pythonPath" 改为Python3的路径:

    // Linux系统的Python3路径
    "python.pythonPath": "/usr/bin/python3",

    对于Windows系统,以上Python3路径应设置为:

    // Windows系统的Python3路径
    "python.pythonPath": "x:\\xxx\\Python3x\\python.exe",

vscode报错:Formatter yapf is not installed

与上面 Linter pylint is not installed 报错类似,先确认是否已正确安装 yapf,再找到设置语句 "python.formatting.yapfPath": "yapf" 将其修改为正确调用路径,最后检查多版本共存情况下的Python路径。

  • 8
    点赞
  • 77
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
### 回答1: 有很多 VS Code 的插件可以用来格式化 Python 代码,以下是其中一些比较常用的插件: 1. Prettier - Code formatter: 这是一个通用的代码格式化插件,支持多种语言,包括 Python。可以通过设置来定制格式化规则。 2. autopep8: 这是一个专门用来格式化 Python 代码的插件,可以设置自动格式化和手动格式化两种模式。 3. yapf: 这是另一个专门用来格式化 Python 代码的插件,可以通过设置来调整格式化规则和风格。 以上是一些比较常用的插件,你可以根据自己的需求选择适合自己的插件。 ### 回答2: VSCode 是一款非常受欢迎的开源代码编辑器,它有许多强大的插件可以扩展其功能。对于 Python 开发者来说,格式化代码是一项非常重要的任务,它可以提高代码的可读性和可维护性。在 VSCode 中,有几个插件可以帮助我们快速格式化 Python 代码。 首先,Python 插件本身就已经内置了代码格式化功能。它基于 PEP 8 标准,可以自动对齐缩进、调整空格等。我们只需要在 VSCode 中选择要格式化代码,然后按下快捷键 Shift + Alt + F,或者右键点击选择 "Format Document",就可以对代码进行格式化了。 此外,VSCode 还支持安装其他格式化代码的插件。其中一个非常受欢迎的插件是 "Python Autopep8",它是由 Autopep8 工具提供支持的。Autopep8 是一个流行的 Python 代码格式化工具,可以根据 PEP 8 标准自动对齐代码、调整空格等。安装了 "Python Autopep8" 后,可以在 VSCode 中的扩展管理器中搜索并安装该插件。安装完成后,代码保存时会自动进行格式化,也可以通过按下快捷键 Ctrl + Shift + P,然后输入 "Python: Format Document with Autopep8" 来手动触发格式化。 除了 "Python Autopep8" 插件,还有其他一些格式化插件,如 "Black"、"Pylint" 等,它们也能帮助我们格式化 Python 代码。这些插件可以根据个人偏好和项目需求进行选择和配置。 总之,VSCode 提供了多种插件供我们选择,以便于格式化 Python 代码。这些插件可以提高代码的可读性,使我们的开发过程更加高效和愉快。无论是使用内置的格式化功能还是安装额外的插件,我们都可以轻松地管理和格式化我们的 Python 代码。 ### 回答3: VS Code 是一款功能强大的代码编辑器,而且支持众多编程语言,包括 Python。为了帮助开发者更高效地编写和排查代码,VS Code 提供了许多插件。其中一个常用的插件便是用于格式化 Python 代码的。下面我将详细介绍几款常用的格式化插件。 首先是 Pylance 插件。Pylance 是由微软开发的一款 Python 语言服务器插件,它不仅提供了代码补全、跳转、重构等常用功能,还能自动格式化你的 Python 代码。你可以按下快捷键(例如 Ctrl + Shift + I)来运行格式化命令,亦或是在保存代码时自动执行格式化。Pylance 支持许多格式化选项,例如对齐、缩进、空格等,方便你根据团队或个人的编码规范进行自定义设置。 另外一个常用的插件是 autopep8。这个插件是基于 Python 代码风格指南 PEP 8 开发的,通过解析代码并自动修复格式错误来确保你的 Python 代码符合规范。该插件可以通过在命令面板中输入 "autopep8" 并选择相应的命令来格式化代码。 最后还有 black 插件。black 是一个强大的 Python 代码格式化工具,它使用一种称为 "black magic" 的算法来确保生成高质量的、一致的代码。安装完 black 插件后,你可以按下快捷键(例如 Alt + Shift + F)来格式化选中的代码块,亦或是整个文件。 总结一下,VS Code 提供了多款格式化 Python 代码的插件,其中包括 Pylance、autopep8 和 black。这些插件可以帮助开发者更好地维护和组织代码,提高编程效率,并确保代码的一致性和可读性。你可以根据个人喜好和项目需求选择适合自己的插件来格式化代码

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值