开元周游
德国频道
查看: 923|回复: 0
打印 上一主题 下一主题

神奇的VIM zz

[复制链接]
1#
发表于 16.11.2002 11:32:38 | 只看该作者
神奇的VIM<br />内容:<br />例一<br />例二<br />例三<br />例四<br />例五<br />例六<br />关于作者<br /><br />闫石 (iloveibm@163.com)<br />工程师<br />当今世界,文本编辑器种类繁多,大有&quot;乱花渐欲迷人眼&quot;之势。中国有句古语:手巧不如家什妙,作为IT业的专业人士,选择一款优秀的编辑软件至关重要。笔者认为:LINUX下的VIM※以其强大的功能和无穷的魅力将使您终生受益。<br /><br />由于被广泛移植,无论是PC机的DOS和WINDOWS,还是RISC/6000的AIX,乃至于IBM的大型机S/390,都能见到VIM的身影。然而,对于初学者,VIM的用户界面与使用方法非常不符合常规,甚至认为它比较混乱,无所适从。事实上,VIM编辑器是专门为经验丰富的用户设计的,它的界面和使用方法提供了更快的速度和更强的功能。对于熟知它的用户,VIM的许多特性节省了时间和击键次数,并可以完成一些其他编辑器无法完成的功能。<br /><br />学习的最好方法是实践,唯有如此,才能真正掌握其中的精髓。文中列举的实例,都是笔者在实际工作中遇到的,具有一定的代表性,请大家在阅读的过程中仔细体会。<br /><br />好了,现在让我们共同畅游神奇的VIM的世界!<br /><br />例一、两个常用的指令序列<br /><br />   1. xp 左右交换光标处两字符的位置。<br />   2. ddp 上下交换光标处两行的位置。 <br /><br />例二、重复输入同一字符<br /><br />有时,我们可能想多次输入同一字符,VIM的插入功能可以很好的完成这项工作<br /><br />命令 80i=^ESC 一次可以输入80个字符= ,当然,80a=^ESC 也可以完成上述功能。<br /><br />请注意:此处的^ESC表示键盘左上方上的ESC键。<br /><br />例三、将两个文本数据文件按行逐条合并,并给出标尺<br /><br />数据文件1内容如下:<br />1-----<br />2-----<br />3-----<br /><br />数据文件2内容如下:<br />1=====<br />2=====<br />3=====<br /><br />要求的结果如下:<br />|--------1---------2---------3---------4---------5<br />1-----<br />1=====<br />|--------1---------2---------3---------4---------5<br />2-----<br />2=====<br />|--------1---------2---------3---------4---------5<br />3-----<br />3=====<br /><br />也许您会说,这还不简单,无非是反复拷贝、粘贴,任何一款文本编辑器都能完成上述功能。可是,如果这两个文件都很大,每个文件都成千上万行,恐怕简单的拷贝、粘贴就难以胜任了。因此,我们所关心的,是找到一种行之有效的方法,把枯燥乏味的工作留给计算机,我们只需发布指令。为达到此目的,请按以下步骤执行:<br /><br />㈠、将两文件合并,结果如下<br />1-----<br />2-----<br />3-----<br />1=====<br />2=====<br />3=====<br /><br />㈡、在两文件头尾相接的地方插入标志行,用以区分两个文件,本文采用的是一整行!字符<br />1-----<br />2-----<br />3-----<br />&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;<br />1=====<br />2=====<br />3=====<br /><br />㈢、在标志行的下方输入标尺<br />1-----<br />2-----<br />3-----<br />&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;<br />|--------1---------2---------3---------4---------5<br />1=====<br />2=====<br />3=====<br /><br />㈣、执行宏命令脚本merge_2r.vim,即在VIM编辑器中按如下键 <!--emo&:s--><img src='style_emoticons/<#EMO_DIR#>/confused_smile.gif' border='0' style='vertical-align:middle' alt='confused_smile.gif' /><!--endemo-->o merge_2r.vim 回车<br /><br />㈤、按下键盘上的=键,执行的结果如下<br />|--------1---------2---------3---------4---------5<br />1-----<br />1=====<br />|--------1---------2---------3---------4---------5<br />2-----<br />2=====<br />|--------1---------2---------3---------4---------5<br />3-----<br />3=====<br />|--------1---------2---------3---------4---------5<br />&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;<br />|--------1---------2---------3---------4---------5<br /><br />㈥、将最后三行删除,即可得到我们需要的结果<br />|--------1---------2---------3---------4---------5<br />1-----<br />1=====<br />|--------1---------2---------3---------4---------5<br />2-----<br />2=====<br />|--------1---------2---------3---------4---------5<br />3-----<br />3=====<br /><br />怎么样,简单吗?请大家自己实际尝试一下。下面,我来详细讲解宏命令脚本merge_2r.vim 。<br /><br />该脚本内容如下:<br /><br /><br />&quot;--------------------------------------------------------------------<br />&quot;Macro Function :  Merge   File1 And File2,Have Ruler in every record<br />&quot;          Date :  2001/12/01<br />&quot;        Author :  Yan Shi<br />&quot;--------------------------------------------------------------------<br />&quot;1----- <br />&quot;2-----                                               }  Sample File1<br />&quot;3-----<br />&quot;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;                                  Flag Row<br />&quot;|--------1---------2---------3---------4---------5          Ruler<br />&quot;1===== <br />&quot;2=====                                               }  Sample File2<br />&quot;3===== <br />&quot;--------------------------------------------------------------------<br />:1<br />:map = ma/&#33;&#33;&#33;&#33;&#33;^M+:.co &#39;a-1^M/&#33;&#33;&#33;&#33;&#33;^M2+:.m&#39;a^M+=<br /><br />前14行每行都以&quot;开始,表明该行是注释行,实际并不执行,只是方便读者阅读,只有最后两行才是真正的代码行。请注意:本例中的^M表示键盘上的回车键,并非^和M两个字符。为了讲述清楚,我把命令行分解开,逐一说明。<br /><br />首先将第一行置为当前行,然后执行map命令,将一大串VIM指令映像给字符=。这一大串VIM指令共分9步执行:<br /><br />   1.<br /><br />      ma 将数据文件一的第一行标记为a<br />      1-----<br />      2-----<br />      3-----<br />      &#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;<br />      |--------1---------2---------3---------4---------5<br />      1=====<br />      2=====<br />      3=====<br />   2.<br /><br />      /&#33;&#33;&#33;&#33;&#33;^M 找到标志行,置为当前行<br />      1-----<br />      2-----<br />      3-----<br />      &#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;<br />      |--------1---------2---------3---------4---------5<br />      1=====<br />      2=====<br />      3=====<br />   3.<br /><br />      + 光标下移一行,即把标尺行置为当前行<br />      1-----<br />      2-----<br />      3-----<br />      &#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;<br />      |--------1---------2---------3---------4---------5<br />      1=====<br />      2=====<br />      3=====<br />   4.<br /><br />      :.co &#39;a-1^M 把标尺行复制到标记行(数据文件一的第一行)的上方<br />      |--------1---------2---------3---------4---------5<br />      1-----<br />      2-----<br />      3-----<br />      &#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;<br />      |--------1---------2---------3---------4---------5<br />      1=====<br />      2=====<br />      3=====<br />   5.<br /><br />      /&#33;&#33;&#33;&#33;&#33;^M 再次找到标志行,置为当前行<br />      |--------1---------2---------3---------4---------5<br />      1-----<br />      2-----<br />      3-----<br />      &#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;<br />      |--------1---------2---------3---------4---------5<br />      1=====<br />      2=====<br />      3=====<br />   6.<br /><br />      2+ 光标下移2行,即数据文件二的第一行置为当前行<br />      |--------1---------2---------3---------4---------5<br />      1-----<br />      2-----<br />      3-----<br />      &#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;<br />      |--------1---------2---------3---------4---------5<br />      1=====<br />      2=====<br />      3=====<br />   7.<br /><br />      :.m&#39;a^M 把数据文件二的第一行移至标记行的下方<br />      |--------1---------2---------3---------4---------5<br />      1-----<br />      1=====<br />      2-----<br />      3-----<br />      &#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;<br />      |--------1---------2---------3---------4---------5<br />      2=====<br />      3=====<br />   8.<br /><br />      + 光标下移一行,即数据文件一的第二行置为当前行<br />      |--------1---------2---------3---------4---------5<br />      1-----<br />      1=====<br />      2-----<br />      3-----<br />      &#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;&#33;<br />      |--------1---------2---------3---------4---------5<br />      2=====<br />      3=====<br />   9.<br /><br />      = 这一步很关键,是典型的递归调用,重复完成以上步骤<br /><br />例四、在文件中置入行号<br /><br />工作中,我们有时希望把行号置入文件中,而VIM提供的功能 :set nu 只能显示行号,不能编辑或将其置入文件当中,下面的宏命令脚本row_num.vim可以完成此项功能。<br /><br /><br /><br />&quot;------------------------------------------<br />&quot;Macro Function :  Source File Add Row_Num<br />&quot;          Date :  2001/12/01<br />&quot;        Author :  Yan Shi<br />&quot;------------------------------------------<br />:%s/^/^I/<br /><!--emo&:$--><img src='style_emoticons/<#EMO_DIR#>/embaressed_smile.gif' border='0' style='vertical-align:middle' alt='embaressed_smile.gif' /><!--endemo--><br />:let end=line(&quot;.&quot;)<br />:1<br />&quot;------------------------------------------<br />:let num=1<br />:while num&lt;=end<br />    :let  line=getline(&quot;.&quot;)<br />    :let  temp=substitute(line,$,num,&quot;&quot;)<br />    :call setline(&quot;.&quot;,temp)<br />    :+<br />    :let  num=num+1<br />:endwhile<br />&quot;------------------------------------------<br /><br />请注意:本例中的^I表示键盘上的TAB键,并非^和I两个字符。下面,我针对该宏命令脚本逐一讲解。<br /><br /><br /><br />:%s/^/^I/           每一行的行首添加一个TAB字符<br /><!--emo&:$--><img src='style_emoticons/<#EMO_DIR#>/embaressed_smile.gif' border='0' style='vertical-align:middle' alt='embaressed_smile.gif' /><!--endemo-->                  到文件的末行<br />:let end=line(&quot;.&quot;)  末行的行号 ==〉变量 END,函数line的功能是取得指定行的行号,此处参数&quot;.&quot;表示当前行<br />:1                  到文件的首行<br />&quot;------------------------------------------<br />:let num=1          1 ==〉计数器<br />:while num&lt;=end<br />    :let  line=getline(&quot;.&quot;)    取当前行的内容 ==〉变量 LINE<br />    :let  line=substitute(line,$,num,&quot;&quot;)    在变量 LINE 的前面置入行号<br />    :call setline(&quot;.&quot;,line)    将变量 LINE 的内容写回当前行<br />    :+              下移一行<br />    :let  num=num+1 计数器加一<br />:endwhile           循环执行,直到文件结束<br />&quot;------------------------------------------<br /><br />有关正则表达式的使用<br /><br />UNIX/LINUX下的很多工具之所以强大、灵活,关键是因为有了正则文法和元字符,这也是VIM乃至UNIX/LINUX系统的精华所在。正因为使用灵活,因此掌握起来比较吃力,如果不是真正理解,实际运用中会出现千奇百怪的错误。因此,有必要对这部分知识多花些气力。下面结合具体实例讲解。<br /><br />例五、有一文件,包含某外企的中国员工的资料,首先是姓名,然后是两个空格,其次是15位身份证号码。<br /><br /><br />zhang.fei  430759701022003<br />diao.chan  651302801225012<br />guan.yu  342869680413001<br />xi.shi  120638780214006<br />liu.bei  210324650708001<br /><br />现在,有以下问题需要解决:<br /><br />   1. 按照外国人的习惯,应该是名在前,姓在后。因此,文件中的姓名字段需要修改。<br />   2. 姓与名的首字母应该大写。<br />   3. 根据身份证号码,还可以判断出生年月日,将其作为一个新字段添加。<br />   4. 根据身份证号码,可以判断出性别。若为男性,添加male,若为女性,添加female 。<br />   5. 将男女员工分开,男员工在前,女员工在后。<br />   6. 将各字段数据左对齐 <br /><br />最终结果如下:<br /><br /><br />Fei.Zhang   430759701022003  1970/10/22  male  <br />Yu.Guan     342869680413001  1968/04/13  male  <br />Bei.Liu     210324650708001  1965/07/08  male  <br />-----------------------------------------------<br />Chan.Diao   651302801225012  1980/12/25  female<br />Shi.Xi      120638780214006  1978/02/14  female<br /><br />为了完成上述功能,只需执行脚本employee.vim ,使用方法为 <!--emo&:s--><img src='style_emoticons/<#EMO_DIR#>/confused_smile.gif' border='0' style='vertical-align:middle' alt='confused_smile.gif' /><!--endemo-->o employee.vim 回车即可。<br /><br />脚本内容如下:<br /><br /><br /><br />:%s/  /          /<br />:%s/\(............\)\(  *\)/\1/<br />:%s/\([A-Za-z][A-Za-z]*\)\(\.\)\([A-Za-z][A-Za-z]*\)/\u\3\2\u\1/<br />:%s/$/  xxxxxx/<br />:%s/\([0-9]\{6}\)\([0-9]\{6}\)\([0-9]\{3}\)  \(xxxxxx\)/\1\2\3  \2/<br />:%s/\(..\)\(..\)\(..\)$/19\1\/\2\/\3<br />:%s/$/  xxxxxx/<br />:%s/\([0-9]\{14}[13579]\)\(.*\)\(xxxxxx\)/\1\2male  /<br />:%s/\([0-9]\{14}[02468]\)\(.*\)\(xxxxxx\)/\1\2female/<br /><!--emo&:$--><img src='style_emoticons/<#EMO_DIR#>/embaressed_smile.gif' border='0' style='vertical-align:middle' alt='embaressed_smile.gif' /><!--endemo--><br /><!--emo&:s--><img src='style_emoticons/<#EMO_DIR#>/confused_smile.gif' border='0' style='vertical-align:middle' alt='confused_smile.gif' /><!--endemo-->/.*/&amp;^M-----------------------------------------------<br />:g/female/.m$<br /><br />在这个脚本中,使用了大量的正则表达式,这里仅对涉及到的正则表达式做一简要介绍。有关正则表达式的内容相当多,本文不可能占用大量篇幅叙述,请大家谅解。<br /><br />% 地址范围符号,代表文件中的所有行,作用等同于地址范围 1,$<br />. 与任意单字符(换行符除外)匹配,例如 y.s 可以匹配 yas y.s 或 y s 等等。<br />* 与前一字符的0次或多次出现匹配,例如 y*s 可以匹配 yys yyyyys 或 s 等等。<br />$ 与行尾匹配。<br />&amp; 代表模式匹配中出现的字符串,例如 s/abc/&amp;def 是把当前行的abc替换成abcdef 。<br />[] 匹配[]中出现的字符,例如[abc]匹配字符 a,b 或 c ,[a-zA-Z]匹配所有的英文字符。<br />\( \) \(和\)之间出现的内容可以由\num来替代。<br />\1\2\3 替代\(和\)之间出现的内容。<br />\u 将后续字符串的首字母大写。<br />\{num} 与前一字符的num次出现匹配。<br /><br />现在,我们对脚本逐条讲解,希望能帮助大家理解正则文法。<br /><br />⑴:%s/ / /<br />将文件中每行出现的2个空格替换为10个空格。<br /><br /><br />zhang.fei          430759701022003<br />diao.chan          651302801225012<br />guan.yu          342869680413001<br />xi.shi          120638780214006<br />liu.bei          210324650708001<br /><br />⑵:%s/\(............\)\( *\)/\1/<br />保留行首的12个字符,将其余的空格删除,这样,前两个字段就对齐了。<br /><br /><br />zhang.fei   430759701022003<br />diao.chan   651302801225012<br />guan.yu     342869680413001<br />xi.shi      120638780214006<br />liu.bei     210324650708001<br /><br />⑶:%s/\([A-Za-z][A-Za-z]*\)\(\.\)\([A-Za-z][A-Za-z]*\)/\u\3\2\u\1/<br />将文件中每行出现的雇员姓名互换,并将首字母大写。<br /><br /><br />Fei.Zhang   430759701022003<br />Chan.Diao   651302801225012<br />Yu.Guan     342869680413001<br />Shi.Xi      120638780214006<br />Bei.Liu     210324650708001<br /><br />⑷:%s/$/ xxxxxx/<br />在每一行的行尾添加2个空格和6个x<br /><br /><br /><br />Fei.Zhang   430759701022003  xxxxxx<br />Chan.Diao   651302801225012  xxxxxx<br />Yu.Guan     342869680413001  xxxxxx<br />Shi.Xi      120638780214006  xxxxxx<br />Bei.Liu     210324650708001  xxxxxx<br /><br />⑸:%s/\([0-9]\{6}\)\([0-9]\{6}\)\([0-9]\{3}\) \(xxxxxx\)/\1\2\3 \2/<br />将xxxxxx替换成出生年月日。<br /><br /><br />Fei.Zhang   430759701022003  701022<br />Chan.Diao   651302801225012  801225<br />Yu.Guan     342869680413001  680413<br />Shi.Xi      120638780214006  780214<br />Bei.Liu     210324650708001  650708<br /><br />⑹:%s/\(..\)\(..\)\(..\)$/19\1\/\2\/\3<br />将年月日用/字符分隔,并在年前添加19。<br /><br /><br />Fei.Zhang   430759701022003  1970/10/22<br />Chan.Diao   651302801225012  1980/12/25<br />Yu.Guan     342869680413001  1968/04/13<br />Shi.Xi      120638780214006  1978/02/14<br />Bei.Liu     210324650708001  1965/07/08<br /><br />⑺:%s/$/ xxxxxx/<br />在每一行的行尾添加2个空格和6个x<br /><br /><br />Fei.Zhang   430759701022003  1970/10/22  xxxxxx<br />Chan.Diao   651302801225012  1980/12/25  xxxxxx<br />Yu.Guan     342869680413001  1968/04/13  xxxxxx<br />Shi.Xi      120638780214006  1978/02/14  xxxxxx<br />Bei.Liu     210324650708001  1965/07/08  xxxxxx<br /><br />⑻:%s/\([0-9]\{14}[13579]\)\(.*\)\(xxxxxx\)/\1\2male /<br />身份证号码末位是奇数的,将xxxxxx替换成male<br /><br /><br />Fei.Zhang   430759701022003  1970/10/22  male  <br />Chan.Diao   651302801225012  1980/12/25  xxxxxx<br />Yu.Guan     342869680413001  1968/04/13  male  <br />Shi.Xi      120638780214006  1978/02/14  xxxxxx<br />Bei.Liu     210324650708001  1965/07/08  male  <br /><br />⑼:%s/\([0-9]\{14}[02468]\)\(.*\)\(xxxxxx\)/\1\2female/<br />身份证号码末位是偶数的,将xxxxxx替换成female<br /><br /><br />Fei.Zhang   430759701022003  1970/10/22  male  <br />Chan.Diao   651302801225012  1980/12/25  female<br />Yu.Guan     342869680413001  1968/04/13  male  <br />Shi.Xi      120638780214006  1978/02/14  female<br />Bei.Liu     210324650708001  1965/07/08  male  <br /><br />⑽<!--emo&:$--><img src='style_emoticons/<#EMO_DIR#>/embaressed_smile.gif' border='0' style='vertical-align:middle' alt='embaressed_smile.gif' /><!--endemo--> 到文件的最后一行<br /><br />⑾<!--emo&:s--><img src='style_emoticons/<#EMO_DIR#>/confused_smile.gif' border='0' style='vertical-align:middle' alt='confused_smile.gif' /><!--endemo-->/.*/&amp;^M-----------------------------------------------<br />在文件的最末行插入一行 &quot;-&quot; 字符。<br /><br /><br />Fei.Zhang   430759701022003  1970/10/22  male  <br />Chan.Diao   651302801225012  1980/12/25  female<br />Yu.Guan     342869680413001  1968/04/13  male  <br />Shi.Xi      120638780214006  1978/02/14  female<br />Bei.Liu     210324650708001  1965/07/08  male  <br />-----------------------------------------------<br /><br />⑿:g/female/.m$<br />将所有的女员工记录移至文件尾。<br /><br /><br />Fei.Zhang   430759701022003  1970/10/22  male  <br />Yu.Guan     342869680413001  1968/04/13  male  <br />Bei.Liu     210324650708001  1965/07/08  male  <br />-----------------------------------------------<br />Chan.Diao   651302801225012  1980/12/25  female<br />Shi.Xi      120638780214006  1978/02/14  female<br /><br />笔者目前正在为某外资公司从事大型机(IBM S/390)的软件开发,一切工作都在TSO环境中进行。为了对编写的程序进行测试,必须准备测试数据。有过大型机开发经验的人会知道,通过TSO,输入字符型数据还可以,如果要输入16进制数据,操作起来很麻烦。因为16进制数是纵向排列的,输入时既不方便,又很容易错位。怎么解决呢?我尝试了几种办法,实际证明,用VIM最方便。<br /><br />例六、下列数据 1234567890ABCDEF ,将其变成 13579ACE 24680BDF 的形式,这样,数据就可以很方便的粘贴到TSO环境中了。<br /><br />下面给出宏命令脚本change_d.vim<br /><br /><br /><br />&quot;----------------------------------------------------<br />&quot;Macro Function :  Convert Char Arrange Direction<br />&quot;<br />&quot;        Sample :  40 50 60 ==&gt; 4 5 6<br />&quot;                               0 0 0<br />&quot;          Date :  2001/12/01<br />&quot;        Author :  Yan Shi<br />&quot;----------------------------------------------------<br /><!--emo&:s--><img src='style_emoticons/<#EMO_DIR#>/confused_smile.gif' border='0' style='vertical-align:middle' alt='confused_smile.gif' /><!--endemo-->/.*/&amp;^M/<br />:1<br />:map = malx+$p-`al=<br /><br />说明如下:<br /><br /><br /><br />⑴ <!--emo&:s--><img src='style_emoticons/<#EMO_DIR#>/confused_smile.gif' border='0' style='vertical-align:middle' alt='confused_smile.gif' /><!--endemo-->/.*/&amp;^M/             在数据行下方添加一空行。<br />⑵ :1                     回到文件的首行的首字符。<br />⑶ :map = malx+$p-`al=    将一大串VIM命令映像给字符=<br /><br />① ma  将首字符标记为a<br />② l   光标右移一个字符<br />③ x   删除光标处字符<br />④ +   移至下一行<br />⑤ $   到行尾<br />⑥ p   将删除的字符粘贴<br />⑦ -   回至上一行<br />⑧ `a  返回到标记字符处<br />⑨ l   光标右移一个字符<br />⑩ =   递归调用,重复以上步骤,直到将该行所有的数据处理完。<br /><br />上面的这几个实例,展示了VIM强大的文本处理功能,但这远不能覆盖其全貌。VIM的命令很多,而且使用灵活,需要狠下一番气力才能熟练掌握。笔者年龄尚小,经验还很欠缺,希望本文能够起到抛砖引玉的作用。由于时间的原因,上述实例仅在DOS和WINDOWS环境下测试,没有在其他系统下进行进一步的测试,希望各位同行、前辈不吝赐教,谢谢!<br /><br />※ VIM 意为 VI Improved ,与VI99%向下兼容。而且,VIM提供了许多VI不具备的功能,内置了诸多函数,因此,建议有经验的VI用户对VIM有所了解,您会发现,转向VIM是明智之举。欲查询有关VIM的资料,请参考 http://www.vim.org<br /><br />注:本文使用 VIM 6.0 版本<br />作者简介<br />闫石,工程师。您可以通过电子邮件:iloveibm@163.com 或者 yan-shi@sino-com.com 和他联系。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

站点信息

站点统计| 举报| Archiver| 手机版| 小黑屋

Powered by Discuz! X3.2 © 2001-2014 Comsenz Inc.

GMT+1, 26.12.2024 20:15

关于我们|Apps

() 开元网

快速回复 返回顶部 返回列表