Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1792391
  • 博文数量: 306
  • 博客积分: 3133
  • 博客等级: 中校
  • 技术积分: 3932
  • 用 户 组: 普通用户
  • 注册时间: 2009-04-19 16:50
文章分类

全部博文(306)

文章存档

2018年(7)

2017年(18)

2016年(39)

2015年(35)

2014年(52)

2013年(39)

2012年(22)

2011年(29)

2010年(53)

2009年(12)

分类: LINUX

2014-03-19 14:02:20

好久不用Vim 顺手的东西都忘记了。


全局替换命令格式:

用法为 :[addr]s/源字符串/目的字符串/[option]
全局替换命令为::%s/源字符串/目的字符串/g
[addr] 表示检索范围,省略时表示当前行。
如:“1,20” :表示从第1行到20行;
“%” :表示整个文件,同“1,$”;
“. ,$” :从当前行到文件尾;
s : 表示替换操作
[option] : 表示操作类型
如:g 表示全局替换; 
c 表示进行确认
p 表示替代结果逐行显示(Ctrl + L恢复屏幕);
省略option时仅对每行第一个匹配串进行替换;
如果在源字符串和目的字符串中出现特殊字符,需要用”\”转义
下面是一些例子:
#将That or this 换成 This or that
:%s/\(That\) or \(this\)/\u\2 or \l\1/
—- 
#将句尾的child换成children
:%s/child\([ ,.;!:?]\)/children\1/g
—-
#将mgi/r/abox换成mgi/r/asquare
:g/mg\([ira]\)box/s//mg//my\1square/g    <=>  :g/mg[ira]box/s/box/square/g
—-
#将多个空格换成一个空格
:%s/  */ /g
—-
#使用空格替换句号或者冒号后面的一个或者多个空格
:%s/\([:.]\)  */\1 /g
—-
#删除所有空行
:g/^$/d
—-
#删除所有的空白行和空行
:g/^[  ][  ]*$/d
—-
#在每行的开始插入两个空白
:%s/^/>  /
—-
#在接下来的6行末尾加入.
:.,5/$/./
—-
#颠倒文件的行序
:g/.*/m0O  <=> :g/^/m0O
—-
#寻找不是数字的开始行,并将其移到文件尾部
:g!/^[0-9]/m$ <=> g/^[^0-9]/m$
—-
#将文件的第12到17行内容复制10词放到当前文件的尾部
:1,10g/^/12,17t$
~~~~重复次数的作用
—-
#将chapter开始行下面的第二行的内容写道begin文件中
:g/^chapter/.+2w>>begin
—-
:/^part2/,/^part3/g/^chapter/.+2w>>begin
—-
:/^part2/,/^part3/g/^chapter/.+2w>>begin|+t$

正则表达式:


Vim中的正则表达式功能很强大,如果能自由运用,则可以完成很多难以想象的操作。
如果你比较熟悉Perl的正规表达式,可以直接参照

一节。
使用正则表达式的命令
使用正则表达式的命令最常见的就是 / (搜索)命令。其格式如下:
/正则表达式
另一个很有用的命令就是 :s(替换)命令,将第一个//之间的正则表达式替换成第二个//之间的字符串。
:s/正则表达式/替换字符串/选项
在学习正则表达式时可以利用 / 命令来练习。
元字符
元字符是具有特殊意义的字符。使用元字符可以表达任意字符行首行尾某几个字符等意义。
元字符一览
元字符
说明
.
匹配任意一个字符
[abc]
匹配方括号中的任意一个字符。可以使用-表示字符范围,
[a-z0-9]匹配小写字母和阿拉伯数字。
[^abc]
在方括号内开头使用^符号,表示匹配除方括号中字符之外的任意字符。
\d
匹配阿拉伯数字,等同于[0-9]
\D
匹配阿拉伯数字之外的任意字符,等同于[^0-9]
\x
匹配十六进制数字,等同于[0-9A-Fa-f]
\X
匹配十六进制数字,等同于[^0-9A-Fa-f]
\w
匹配单词字母,等同于[0-9A-Za-z_]
\W
匹配单词字母之外的任意字符,等同于[^0-9A-Za-z_]
\t
匹配字符。
\s
匹配空白字符,等同于[ \t]
\S
匹配非空白字符,等同于[^ \t]
另外,如果要查找字符 *、.、/等,则需要在前面用 \ 符号,表示这不是元字符,而只是普通字符而已。
元字符
说明
\*
匹配 * 字符。
\.
匹配 . 字符。
\/
匹配 / 字符。
\\
匹配 \ 字符。
\[
匹配 [ 字符。
表示数量的元字符
元字符
说明
*
匹配0-任意个
\+
匹配1-任意个
\?
匹配0-1个
\{n,m}
匹配n-m个
\{n}
匹配n个
\{n,}
匹配n-任意个
\{,m}
匹配0-m个
表示位置的符号
元字符
说明
$
匹配行尾
^
匹配行首
\
匹配单词词首
\>
匹配单词词尾
使用例
/char\s\+[A-Za-z_]\w*;                 " 查找所有以char开头,之后是一个以上的空白,
                                             " 最后是一个标识符和分号
/\d\d:\d\d:\d\d                        " 查找如 17:37:01 格式的时间字符串
:g/^\s*$/d                             " 删除只有空白的行
:s/\/4/g                        " 将所有的four替换成4,但是fourteen中的four不替换
替换变量
在正规表达式中使用 \( 和 \) 符号括起正规表达式,即可在后面使用\1\2等变量来访问 \( 和 \) 中的内容。
使用例
/\(a\+\)[^a]\+\1                                          " 查找开头和结尾处a的个数相同的字符串,
                                                                  " 如 aabbbaa,aaacccaaa,但是不匹配 abbbaa
:s/\(http:\/\/[-a-z\._~\+%\/]\+\)/\1/   " 将URL替换为的格式
:s/\(\w\+\)\s\+\(\w\+\)/\2\t\1                            " 将 data1 data2 修改为 data2 data1
函数式
在替换命令 s/// 中可以使用函数表达式来书写替换内容,格式为
:s/替换字符串/\=函数式
在函数式中可以使用 submatch(1)、submatch(2) 等来引用 \1\2 等的内容,而submatch(0)可以引用匹配的整个内容。
使用例
:%s/\/\=line(".")                              " 将各行的 id 字符串替换为行号
:%s/^\/\=(line(".")-10) .".". submatch(1)    " 将每行开头的单词替换为 (行号-10).单词 的格式,
                                                           " 如第11行的 word 替换成 1. word
与Perl正则表达式的区别
元字符的区别
Vim语法
Perl语法
含义
\+
+
1-任意个
\?
?
0-1个
\{n,m}
{n,m}
n-m个
\(和\)
(和)
分组
阅读(6767) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~