谷歌开源!一个格式化 Python 代码的好帮手

图片

大部分人使用 Python 中的代码格式化工具时都会选择 autopep8 之类的工具,这些工具可能有一定的局限性,比如不会重新格式化已经符合 PEP8 的代码。

而本文即将介绍的 Yapf,不仅能将代码格式化为符合 PEP8 代码指南的格式,还能格式化为符合 Google 代码指南的格式,可选项更多,让你的代码更加漂亮。

1.准备

开始之前,你要确保Python和pip已经成功安装在电脑上。

请选择以下任一种方式输入命令安装依赖

  1. Windows 环境 打开 Cmd (开始-运行-CMD)。
  2. MacOS 环境 打开 Terminal (command+空格输入Terminal)。
  3. 如果你用的是 VSCode编辑器 或 Pycharm,可以直接使用界面下方的Terminal.
pip install yapf

YAPF 支持 Python 2.7 和 3.6.4+。

2.Yapf 使用方法

你可以在命令行中直接使用 Yapf, 参数如下:

yapf [-h] [-v] [-d | -i | -q] [-r | -l START-END] [-e PATTERN]
            [--style STYLE] [--style-help] [--no-local-style] [-p]
            [-vv]
            [files ...]

必选参数:

files 需要被格式化的文件

可选参数:
-h, --help 显示帮助信息
-v, --version 显示程序的版本号
-d, --diff 打印格式化前后差异
-i, --in-place 格式化文件并替换
-q, --quiet 什么都不输出
-r, --recursive 在目录上递归运行
-l START-END, --lines START-END 重新格式化的行范围,基于一个
-e PATTERN, --exclude PATTERN 需要排除的文件
–style STYLE 指定格式化样式(例如“pep8”或“google”)
-p, --parallel 并行格式化(多个文件时有效)
-vv, --verbose 在处理时打印出文件名

举个例子,如果我们有以下的混乱格式代码 1.py :

x = { 'a':37,'b':42,

'c':927}

y = 'hello ''world'
z = 'hello '+'world'
a = 'hello {}'.format('world')
class foo  ( object ):
  def f    (self ):
    return       37*-+2
  def g(self, x,y=42):
      return y
def f  ( a ) :
  return      37+-+a[42-x : y**3]

为了格式化它,我们可以在命令行中执行以下命令:

yapf -i 1.py

效果如下:

在这里插入图片描述

3.Yapf 作为模块使用

Yapf 不仅可以在命令行中使用,我们还可以在项目运行时使用。

一个比较常见的场景是用户在你的 web 网站上提交了 python 代码,你希望能一键格式化这些代码,那将 yapf 作为格式化的模块则再好不过。

Yapf 最主要的两个 API 是 FormatCode 和 FormatFile:

from yapf.yapflib.yapf_api import FormatCode

formatted_code, changed = FormatCode("f ( a = 1, b = 2 )")
print(formatted_code)
# 'f(a=1, b=2)\n'
print(changed)
# True

你还可以传递 style_config 决定使用哪种指南做格式化:

from yapf.yapflib.yapf_api import FormatCode

print(FormatCode("def g():\n return True", style_config='pep8')[0])
# 'def g():\n return True\n'

FormatFile,这个函数可以从文件中读取代码并格式化:

from yapf.yapflib.yapf_api import FormatFile
print(open("foo.py").read())
# a==b
reformatted_code, encoding, changed = FormatFile("foo.py")
print(formatted_code)
# 'a == b\n'
print(encoding)
# 'utf-8'
print(changed)
# True

如果你添加 in_place 参数,它将把格式化后的代码写回文件中:

from yapf.yapflib.yapf_api import FormatFile
print(FormatFile("foo.py", in_place=True)[:2])
# (None, 'utf-8')

print(open("foo.py").read())
# a == b

关于Python学习指南

学好 Python 不论是就业还是做副业赚钱都不错,但要学会 Python 还是要有一个学习规划。最后给大家分享一份全套的 Python 学习资料,给那些想学习 Python 的小伙伴们一点帮助!

包括:Python激活码+安装包、Python web开发,Python爬虫,Python数据分析,人工智能、自动化办公等学习教程。带你从零基础系统性的学好Python!

👉Python所有方向的学习路线👈

Python所有方向路线就是把Python常用的技术点做整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。(全套教程文末领取)

在这里插入图片描述

👉Python学习视频600合集👈

观看零基础学习视频,看视频学习是最快捷也是最有效果的方式,跟着视频中老师的思路,从基础到深入,还是很容易入门的。

在这里插入图片描述

温馨提示:篇幅有限,已打包文件夹,获取方式在:文末

👉Python70个实战练手案例&源码👈

光学理论是没用的,要学会跟着一起敲,要动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。

在这里插入图片描述

👉Python大厂面试资料👈

我们学习Python必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有阿里大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。

在这里插入图片描述

在这里插入图片描述

👉Python副业兼职路线&方法👈

学好 Python 不论是就业还是做副业赚钱都不错,但要学会兼职接单还是要有一个学习规划。

在这里插入图片描述

👉 这份完整版的Python全套学习资料已经上传,朋友们如果需要可以扫描下方CSDN官方认证二维码或者点击链接免费领取保证100%免费

  • 37
    点赞
  • 35
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答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。这些插件可以帮助开发者更好地维护和组织代码,提高编程效率,并确保代码的一致性和可读性。你可以根据个人喜好和项目需求选择适合自己的插件来格式化代码

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值