`
lantian_123
  • 浏览: 1360930 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

每日一Vim(6)常用命令总结

 
阅读更多

每日一Vim(6)

程序员应该知道的100个Vim命令(上)

自从70年代起,Vi就是程序员最好的朋友之一既是你是Vi菜鸟都无所谓,这里为你准备了100条实用的命令列表,以主题的形式组织,他们能让你的代码生活更美好。今天就来点纯练手的东西吧,以后再每个专题说说

基本命令

:e filename   打开文件编辑
:w    保存
:q    退出Vim
:w!    保存文件退出Vim

搜索

/word    从顶部往底部搜索word
?word    从底部往顶部搜索word 
/jo[ha]n       搜索john或joan
/\< the        搜索the或theatre 或then(只要是the开头就行)
/the\>         搜索the或breathe(只要是the结尾就行)
/\< the\>      只搜索the
/\< ....\>     搜索长度为4个字符的字符串
/\<fred\>      搜索fred,alfred 或者 frederick都不能匹配
/fred\|joe     搜fred或joe
/\<\d\d\d\d\>  搜索4位数字的字符串
/^\n\{3}       查找3个空行的地方
:bufdo /searchstr/    在所有打开的(缓冲区)文件中搜索searchstr
:bufdo %s/pattern/replace/ge | update   所有文件中替换

替换

:%s/old/new/g          用new替换文件中出现的所有old
:%s/old/new/gc         与上面这条的作用一样,只不过每替换一个就要确认一次
:2,35s/old/new/g       用new替换2到35行的new
:5,$s/old/new/g        替换4行之后所有old
:%s/^/hello/g          用hello替换所有行首,相当于在行首插入hello
:%s/$/Harry/g          在所有行末加入Harray
:%s/onward/forward/gi  用forward替换onward,忽略大小写
:%s/ *$//g         删除所有行末的空格
:%s/^ *//g         删除所有行首的空格
:g/string/d        删除所有出现有string的行
:v/string/d        删除所有不包含string的行
:s/Bill/Steve/     用Steve替换当前行首次出现的Bill
:s/Bill/Steve/g    用Steve替换当前行出现的所有Bill
:%s#<[^>]\+>##g    删除所有HTMl标签,保留文本
dit   保留当前行html标签,删除文本
:%s/^\(.*\)\n\1$/\1/    Delete lines which appears twice
Ctrl+a    递增当前光标出的数字
Ctrl+x    递减当前光标处的数字
ggVGg?    将全文转换为rot13码,这是一种简单暗号语Rot13,重复执行此命令回复原样

大小写

Vu    当前行转换为小写
VU    当前行转换为大写,当然对中文无效
g~~    大小写置换
vEU    选择性的转换为大小,从光标起始处到
vE~    也是将选中的大写转小写,小写转大写。
ggguG    全文小写,其实我们可以拆分3个命令gg/gu/来记忆
:set ignorecase    搜索时忽略大小写
3
1
分享到:
评论
4 楼 isensen 2013-03-15  
lantian_123 写道
isensen 写道
1. :%s#<[^>]\+>##g         删除所有HTMl标签,保留文本
2. dit                     保留当前行html标签,删除文本
3. :%s/^\(.*\)\n\1$/\1/    Delete lines which appears twice

能解释一下这三个吗?
1. $ 代表全文, s 替换 #井号代表什么? 还有< [什么的, 也不是:s/old/new 格式了啊
2. 不明白 ...试也不知道怎么试
3. 正则有点腿.能解释一下么

嗯,不好意思,基本上命名都没附上解释,以后的章节会详细介绍其语法。

1. 语法 :[range] s/search/replace/[flags] [count]也可以是
        :[range] s#search#replace#[flags] [count],%s指全局替换,“<”指html了向左的标签如"<body>"中的"<","[^>]"指非">"的单个字符,“<[^>]”可以匹配:"<h","<a",但是不能匹配"<>","\+>"指1到多个>字符。##相当于//,也就是替成空白。这条命令也可以简写为::%s/<[^>]*>//g

2.可能是vim的设置或版本问题,我另一电脑也没效果。我之后在查查

3. \(.*\)代表分组的意思,"\"是用来转义的,第一对()中的内容就是用\1表示,,如果还有第二对()就是,\2”。/^\(.*\)\n\1$“此命令中出现\1也就是说重复前面的^\(.*\)\n,这样就代表出现重复的行了,然后在用一行的内容来代替这两行。此命令要先执行:sort才生效

讲的很详细.正则有点头疼.这东西.得经常用才行.:sort没有用过.期待以后详解.每天都来看看.
3 楼 lantian_123 2013-03-15  
isensen 写道
1. :%s#<[^>]\+>##g         删除所有HTMl标签,保留文本
2. dit                     保留当前行html标签,删除文本
3. :%s/^\(.*\)\n\1$/\1/    Delete lines which appears twice

能解释一下这三个吗?
1. $ 代表全文, s 替换 #井号代表什么? 还有< [什么的, 也不是:s/old/new 格式了啊
2. 不明白 ...试也不知道怎么试
3. 正则有点腿.能解释一下么

嗯,不好意思,基本上命名都没附上解释,以后的章节会详细介绍其语法。

1. 语法 :[range] s/search/replace/[flags] [count]也可以是
        :[range] s#search#replace#[flags] [count],%s指全局替换,“<”指html了向左的标签如"<body>"中的"<","[^>]"指非">"的单个字符,“<[^>]”可以匹配:"<h","<a",但是不能匹配"<>","\+>"指1到多个>字符。##相当于//,也就是替成空白。这条命令也可以简写为::%s/<[^>]*>//g

2.可能是vim的设置或版本问题,我另一电脑也没效果。我之后在查查

3. \(.*\)代表分组的意思,"\"是用来转义的,第一对()中的内容就是用\1表示,,如果还有第二对()就是,\2”。/^\(.*\)\n\1$“此命令中出现\1也就是说重复前面的^\(.*\)\n,这样就代表出现重复的行了,然后在用一行的内容来代替这两行。此命令要先执行:sort才生效
2 楼 宋建勇 2013-03-15  
nice 正好在学...
1 楼 isensen 2013-03-15  
1. :%s#<[^>]\+>##g         删除所有HTMl标签,保留文本
2. dit                     保留当前行html标签,删除文本
3. :%s/^\(.*\)\n\1$/\1/    Delete lines which appears twice

能解释一下这三个吗?
1. $ 代表全文, s 替换 #井号代表什么? 还有< [什么的, 也不是:s/old/new 格式了啊
2. 不明白 ...试也不知道怎么试
3. 正则有点腿.能解释一下么

相关推荐

Global site tag (gtag.js) - Google Analytics