python 使用者必备一个游标卡尺是一个经典的梗,因为 python 是通过缩进来区分代码块的(而不是{}或者是其他符号),而不是像其他程序语言,缩进仅仅为了可读性。 这就造成究竟选择通过 tab 缩进还是空格缩进成为了不可调和的矛盾,因为混用两种方法的结果是灾难性的,那么,通过什么办法可以缓解这两者的争议呢?现在最为常用的办法,也是各大 IDE 纷纷采用的方式是将 tab 自动转为若干个空格。 vim 作为这个世界上最为著名的文本编辑器,也提供了这个基本的功能,那么我们如何设置才能开启 tab 与空格的自动替换呢?本文就来详细讲解一下。
vim 中 tab 与相关的配置主要是依赖于以下四个配置项:
下面我们一一来进行讲解。
shiftwidth 用于程序中自动缩进所使用的空白长度指示。 也就是说,当你按下 ==,vim 根据语法解析判断出缩进量后,每个缩进量纲应该填充多少个空格。 最常见的设置是 8,但现在越来越多的人设置为 4,也有不少人喜欢设置为 2 的紧凑感。
tab 所等同的空格长度,也就是当你按下 tab 后,一个 tab 占用多少个空格的位置。 通常的建议是设置为与 shiftwidth 一致。
了解了上面的两个设置项,你可能会产生一个问题,那就是如果 shiftwidth 和 tabstop 设置的不同,比如 shiftwidth 设置为 6,tabstop 设置为 4,当你按下 tab,究竟是会前进一个缩进长度 — 6 个空格的空白空间,还是会前进一个 tab 长度 — 4 个空格的空白空间呢? 在 vim 中,tab 总是前进一个缩进长度的,也就是 shiftwidth 定义的空格数量,但如果这时 shiftwidth 与 tabstop 设置的不同,那么 vim 会尽量多的通过 tab 填充,剩余的用空格填充。 也就是说,针对上面的例子,按下 tab,最直观的,屏幕上光标会前进 6 个空格大小的位置,但事实上,他由一个占有 4 个空格空间的 tab 和两个空格构成,当你接下来连续按下下一个 tab,光标总共前进了 12 个空格大小的位置,而这 12 个空格大小的空间由 3 个 tab 填充。 也就是说,如果你设置了 softtabstop=8,其实际含义是“逢 8 空格进 1 制表符”。
经过对 softtabstop 的讲解,出现了一个新的问题,那就是错误的设置可能导致代码中 tab 与空格混合出现,这对于 python 语言是致命性的,即便不是使用 python,任何程序在不同平台上展示,都可能因为 tab 长度不同造成代码的混乱。
这时我们回到开篇提到的解决办法 — 将 tab 自动转为若干个空格,vim 当然也原生支持这一特性,这就是通过 expandtab 设置项实现的。
通过set expandtab
,每当你输入 tab,都会自动替换为 softtabstop 个空格。
但是,可能你并不想让你的 vim 对所有情况都用空格替换 tab,这时你可以设置:
autocmd FileType py set shiftwidth=4 | set expandtab