让Vim(gVim)更好的支持python语法缩进(强烈推荐)
python逐渐成为笔者最常用的语言之一,因此vim对python有些配置的不合理也渐渐显现出来,这次我们先来解决python的缩进问题。
我们来通过例子来说明,来看一下默认配置下python的缩进情况:
1.dict的语法缩进
1 2 3 4 |
val1 = {
1:"1",
2:"2"
} |
2.list的语法缩进
1 2 3 4 5 |
val2 = [
1,
2,
3
] |
3.tuple的语法缩进
1 2 3 4 5 |
val3 = (
1,
2,
3
) |
4.函数多行参数的缩进
1 2 3 4 5 |
def fun(
a,
b
):
print a,b |
5.复杂dict中存在):的情况
1 2 3 4 5 6 |
val4 = {
(
1,
2
):1
} |
很遗憾的发现,这几种常用的写法,默认python缩进都没有完美实现,那么是否有办法优化呢?
答案是有的,vim.org上提供了一款更好的python缩进插件:
http://www.vim.org/scripts/script.php?script_id=974
我们来依次对照一下上面的代码,看新的缩进插件效果怎样:
1.dict的语法缩进
1 2 3 4 |
val1 = {
1:"1",
2:"2"
} |
2.list的语法缩进
1 2 3 4 5 |
val2 = [
1,
2,
3
] |
3.tuple的语法缩进
1 2 3 4 5 |
val3 = (
1,
2,
3
) |
4.函数多行参数的缩进
1 2 3 4 5 |
def fun(
a,
b
):
print a,b |
5.复杂dict中存在):的情况
1 2 3 4 5 6 |
val4 = {
(
1,
2
):1
} |
除了第4条依然表现诡异,其他的缩进应该是比较完美了~
OK,重头戏来了,我们去看源码:
对第117行作出如下修改:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 |
"Mod-Begin by dantezhu in 2011-02-21 23:38:24
"FROM
"return indent(parlnum)
"TO
"为了支持如下的格式:
"def fun(
" a,
" b
" ):
" print a,b
"又不影响如下格式:
"val = {
" (
" 1,
" 2
" ):1
"}
if match(getline(a:lnum), \')\\s*:\') != -1 && match(getline(parlnum), \'def\\s\\+\') != -1
return indent(parlnum) + &shiftwidth
else
return indent(parlnum)
endif
"Mod-End |
OK,再来试一下对第4条的缩进如何:
1 2 3 4 5 |
def fun(
a,
b
):
print a,b |
perfect!,哈哈
来说一下修改的方法,简单来说就是判断一下当前行是否为 ):,并且其所对应的(所在的行上是否有 def 关键字,如果同时满足这两个条件,则在(所在行的缩进基础上,再向前缩进一个tab。
提供修改之后的下载链接如下:
http://www.vim.org/scripts/script.php?script_id=3461
OK,就到这里,用vim写python的朋友们,快去试试吧!
建议继续学习:
- vim几个小技巧(批量替换,列编辑) (阅读:36799)
- 简明Vim练级攻略 (阅读:21560)
- Vim下的代码自动补全和代码跳转阅读 (阅读:14931)
- 为什么要用 Emacs/Vim,而不是任何其他编辑器 (阅读:12672)
- 在vim(gvim)中运行终端(对,你没有看错,我也没有写反) (阅读:10125)
- vim入门,进阶与折腾 (阅读:10157)
- 让vim在终端下的配色亮起来! (阅读:9416)
- 最近总结的一些技巧(vim,python,svn,fiddler等) (阅读:7714)
- vim的复制粘贴小结 (阅读:7393)
- Vim 中截取部分内容保存到其他文件 (阅读:6788)
扫一扫订阅我的微信号:IT技术博客大学习
- 作者:Dante 来源: Vimer
- 标签: Vim 缩进
- 发布时间:2011-03-07 22:58:38
-
[866] WordPress插件开发 -- 在插件使用 -
[136] 解决 nginx 反向代理网页首尾出现神秘字 -
[58] 整理了一份招PHP高级工程师的面试题 -
[56] 分享一个JQUERY颜色选择插件 -
[54] 用 Jquery 模拟 select -
[54] CloudSMS:免费匿名的云短信 -
[54] 如何保证一个程序在单台服务器上只有唯一实例( -
[54] Innodb分表太多或者表分区太多,会导致内 -
[52] 全站换域名时利用nginx和javascri -
[50] jQuery性能优化指南
