Google的Python代码格式化工具YAPF详解

 

原文地址:http://geek.csdn.net/news/detail/29735

 

 

介绍

目前用于Python的格式化程序(如autopep8和pep8ify)都用于删除代码中的lint错误。这有很明显的局限性。

YAPF采用了不同的方法,基于Daniel Jasper开发的“'clang-format”。从本质上来说,该算法取走代码并重新排版,以符合样式指南的最佳格式,即便原始代码没有违反样式指南。这个想法也是类似于Go编程语言的gofmt工具。

其最终目标是让YAPE所产生的代码可以与程序员所写的代码一样好(前提是程序员遵循样式指南),它取代了一些维护代码的苦差。

 

 

安装

项目地址:https://github.com/google/yapf
如果你打算使用YAPF作为一个命令行工具,而不是一个库,那么安装是没有必要的。通过Python解释器,YAPF可以作为一个目录运行。如果你克隆/解压YAPF到DIR,可以这么运行:

$ PYTHONPATH=DIR python DIR/yapf [options] ...

 

 

Python版本

YAPF支持Python2.7和3.4+。

 

 

用法: (使用前请先备份您的代码!!!)

python yapf -i -r --style='{based_on_style: google, indent_width: 4, column_limit: 999}' ${path}

 


设置:

//img-my.csdn.net/uploads/201504/03/1428039886_1797.png

 

 

格式样式

使用YPF的格式样式是可以配置的,并且有许多“knobs”可用于调整YAPF是如何做格式的。(查看style.py模块)

为了控制样式,运行带有--style的YAPF。它接受一个预定义的样式(例如pep8或google)——一个通往配置文件(能指定所需样式或一个键/值对的字典)的途径。

 

配置文件是一个简单的键=值对的列表(区分大小写),拥有一个【style】,例如:

//img-my.csdn.net/uploads/201504/03/1428040100_5148.png

 

当然也可以通过字典在命令行上做出同样的事情,例如:

--style='{basedonstyle: google, indent_width: 4}'

这将用google作为基础样式,并修改成拥有4个空格缩进。

 

案例

通过YAPF,可以将下面这段代码:

//img-my.csdn.net/uploads/201504/03/1428040319_2295.png

 

重新格式化成:

//img-my.csdn.net/uploads/201504/03/1428040355_2787.png

 

 

常见问题

为什么YAPF破坏了我很棒的格式?

对于一些代码,它不会比手动格式好,特别是大的数据文字,在YAPF下会变得更糟糕。引起这些的原因是多样的,但是从本质上来说,YAPF只是一个帮助开发的简单工具,它将事物与样式指南保持一致,但这并不等于可读性。

为减轻这种情况,你需要表明YAPF重新格式化时需要忽视的区域:

//img-my.csdn.net/uploads/201504/03/1428040424_3904.png

 

你也可以禁用格式单一的字面,例如:

//img-my.csdn.net/uploads/201504/03/1428040444_5056.png

 

 

为什么不改善现有的工具?

现有的工具要考虑到不同的目标,并需要大量的修改转换以便使用clang-format算法。我们希望使用clang-format重组算法。

 

 

我可以在程序中使用YAPF吗?

答案是肯定的!YAPF被设计用于作为一个库以及一个命令行工具来使用。这意味着使用YAPF时,一个工具或IDE插件是免费的。​

 

posted @ 2015-04-07 10:51  rilley  阅读(6075)  评论(0编辑  收藏  举报