天天看點

最佳vim技巧

# 基礎

----------------------------------------

* # g* g# : 尋找光标處的狹義單詞(<cword>) (前向/後向)

% : 括号配對尋找 {}[]()

matchit.vim : 使得 % 能夠配對标記  

<script> <?php 等等

<C-N><C-P> : 插入模式下的單詞自動完成

<C-X><C-L> : 行自動完成(超級有用)

/<C-R><C-W> : 把狹義單詞 <cword> 寫到 搜尋指令 行

/<C-R><C-A> : 把廣義單詞 <cWORD> 寫到 搜尋指令 行

:set ignorecase : 搜尋時忽略大小寫

:syntax on : 在 Perl,HTML,PHP 等中進行文法着色

:h regexp<C-D> : 按下 control-D 鍵即可得到包含有 regexp 的幫助主題的清單

: (使用TAB可以實作幫助的自動補齊)

# 使更新 _vimrc 更容易

:nmap ,s :source $VIM/_vimrc

# 譯釋:nmap 是綁定一個在normal模式下的快捷鍵

:nmap ,v :e $VIM/_vimrc

# 譯釋:在normal模式下,先後按下 ,s 兩個鍵執行_vimrc,而 ,v 則是編輯_vimrc

# visual 模式 (例子是:輕松添加其它的 HTML Tags)

:vmap sb "zdi<C-R>z<ESC> :在visual模式下選中的文字前後分别加上和

# 譯釋:vmap 是綁定一個在visual模式下的快捷鍵

# 譯釋:原理:在visual模式下,"zd 把一個選中的區域命名為z 然後删除,

# i 進入插入模式,輸入,<C-R>z 撤銷剛才的删除,然後再寫入,

# 最後<ESC>傳回normal模式

# 譯釋:"z 指令建立一個選中的區域為register,并把它命名為z

# 譯釋:更令人開心的有:在visual模式下選中幾行,然後輸入 2> ,

# 則選中的行會全部縮進兩個tab

# 555,偶一開始還是用 :xx,xx s/^/\t\t/,好傻啊!

:vmap st "zdi<?= <C-R>z ?><ESC> :在visual模式下選中的文字前後分别加上<?= 和 ?>

# 檔案浏覽

:Ex : 開啟目錄浏覽器,注意首字母E是大寫的

:Sex : 在一個分割的視窗中開啟目錄浏覽器

:ls : 顯示目前buffer的情況

:cd .. : 進入父目錄

:args : 顯示目前打開的檔案

:lcd %:p:h : 更改到目前檔案所在的目錄

# 譯釋:lcd是緊緊改變目前視窗的工作路徑,% 是代表目前檔案的檔案名,

# 加上 :p擴充成全名(就是帶了路徑),加上 :h析取出路徑

:autocmd BufEnter * lcd %:p:h : 自動更改到目前檔案所在的目錄

# 譯釋:autocmd指定一個自動指令,BufEnter指定一個事件,* 指定事件的對象,

# lcd %:p:h 指定一個動作

# hehe,好象和寫記叙文差不多

# 緩沖區(buffer)浏覽器 (第三方的一個最流行的腳本)

\be : 在緩沖區浏覽器中打開緩沖區清單

\bs : 以分割視窗的形式打開緩沖區浏覽器

# 大小寫轉換

guu : 行小寫

gUU : 行大寫

g~~ : 行翻轉(當然指大小寫啦)

# 譯釋: g 是大小寫轉換指令(greate),u/U/~是三種轉換形式(小寫/大寫/翻轉),

# 最後一個重複則表示該轉換是對于一行而言的

guw : 字大寫(狹義字) 譯注:建議對比iw

gUw : 字小寫(狹義字)

g~w : 字翻轉(狹義字)

# 譯釋:最後一個w 表示該轉換是對于一個字而言的,由于是在normal模式下,

# 是以這個w 表示一個狹義字<cword>

vEU : 字大寫(廣義字)

vE~ : 字翻轉(廣義字)

# 譯釋:vE 這個指令組合會進入visual模式,然後選擇一個廣義字<CWORD>

ggguG : 把整個文章全部小寫(ft!bt!)

gf : 取目前光标處的廣義字作為檔案名,然後試圖打開它!

# 譯釋:為什麼是廣義字呢?因為這樣可以友善的取到路徑啊,像/var/www/html/index.htm

ga : 顯示光标處字元的ascii,hex,oct,...暈菜的一堆轉換

ggVGg? : 用rot13編碼整個檔案(暈!)

# 譯釋:gg到檔案首行首字元,V進入Visual-Line模式,G到檔案末行首字元,

# 這樣就選中了整篇文章,然後g?就是用rot13編碼整個檔案啦

# 【關于rot13——誰讓英文是偶數個字母啊】

# ROT13 是一種簡單的編碼,它把字母分成前後兩組,每組13個,編碼和譯碼

# 的算法相同,僅僅交換字母的這兩個部分,即:[a..m] --> [n..z] 和 [n..z]

# --> [a..m] 。 ROT13 用簡易的手段使得信件不能直接被識别和閱

# 讀,也不會被搜尋比對程式用通常的方法直接找到。經常用于 USENET 中發表一

# 些攻擊性或令人不快的言論或有簡單保密需要的文章。

# 由于 ROT13 是自逆算法,是以,譯碼和編碼是同一個過程。

<C-A>,<C-X> : 增加,減少 光标處的狹義字所表示的數字

:(,僅僅是分割了這兩個指令,不是指令的一部分)

: Win32的使用者可能需要重新定義一下Ctrl-A,呵呵

# 譯注:good guy, 令人不得不想到perl的數字元串

<C-R>=5*5 : 插入25 (這是一個迷你電腦耶!)

# 好玩的東東

: 第一個結果就是 News. Douglas Adams 1952 - 2001. 

: Floor 42 extends its deepest sympathies to

: the family, friends, and fans of Douglas Adams.

:h holy-grail

:h!

# 标記和移動

'. : 跳到最後修改的那一行 (超級有用)(ft,怎麼又是這個評價)

`. : 不僅跳到最後修改的那一行,還要定位到修改點

<C-O> : 依次沿着你的跳轉記錄向回跳 (從最近的一次開始)

<C-I> : 依次沿着你的跳轉記錄向前跳

:ju(mps) : 列出你跳轉的足迹

:help jump-motions

:history : 列出曆史指令記錄

:his c : 指令行指令曆史

:his s : 搜尋指令曆史

q/ : 搜尋指令曆史的視窗

q: : 指令行指令曆史的視窗

:<C-F> : 曆史指令記錄的視窗

# 縮寫和鍵盤映像(原文中檔案舉例都用了c:/aaa/x,偶全給他改成/path/file了,哼唧)

:map <f7> :'a,'bw! /path/file

# 譯釋:map是映像一個normal模式下的鍵

# 這裡是把F7鍵映像成把标記a到标記b中間的内容另存為一個檔案/path/file

# 标記(mark)的方法:把光标移動到需要标記的地方,輸入m,然後輸入标記名,例如a

# 引用标記的方法:'a ,即:單引号加标記名

:map <f8> :r /path/file

# 譯釋:把F8鍵映像成在目前位置插入檔案/path/file的内容

:map <f11> :.w! /path/file2<CR>

# 譯釋:.(點号)表示目前行

# 是以F11就是把目前行存為/path/file2

# 最後的<CR>表示一個回車

:map <f12> :r /path/file2<CR>

:ab php : 列出php表示的縮寫

# 譯釋:定義一個縮寫使用::iab hm hmisty

# 一個有趣的現象是,它列出的會是php和它的前子串開頭的縮寫

# 例如,有這麼幾個縮寫:

# h => hmisty1 , hm => hmisty2 , hmi => hmisty3, m => hmisty4

# 那麼使用 :ab hm會顯示這麼幾個縮寫:hm 和 h

# 而不是你想象中的 hm 和 hmi

:map , : 列出以逗号開始的鍵盤映像

# 譯釋:一般而言,我們稱這些逗号開始的組合鍵為「逗号指令」

# 不過hmisty更喜歡用;構成「分号指令」

# 而且不是用map,而是用imap

# 因為偶懶麼,懶得按<Esc>,是以直接在insert模式下就執行指令了

# 為什麼用分号呢?因為我最常用它寫程式啊

# perl/C/C++/object pascal/java,都是用分号結束一個語句

# 我們一般很少在分号後面連續寫其它字元

# 是以用「分号+其它鍵」就很少會在輸入的時候造成沖突

# 在鍵盤映像中常用的表示

<CR> : 回車

<ESC> : Esc

<LEADER> : 轉義符号 \

<BAR> : 管道符号 |

# 列出寄存器(Registers)

:reg : 顯示所有目前的registers

"1p : "表示引用register,1表示一個名字叫做1的register,

: p就是粘貼(paste)指令

# 譯釋:"也用來定義register

# 先輸入 ",表示定義register

# 然後輸入名字,如0~9,a~z

# 然後執行删除或複制指令,如dd或y,

# 或者是visual模式下的d(删除選中的部分)或y(複制選中的部分)

# 則被删除或複制的部分就被存入了這個命名的register

#

# 觀察:一個特殊的register, "" ,裡面存儲了一個匿名的删除/複制

# 在你執行dd或y的時候,被作用的部分被存到了""中

# 這些和perl是多麼像啊

# Useful trick

# 譯釋:"ayy 是定義目前行到register a,然後@a是執行register a中存儲的指令

# yy: 複制一行

# 10yy: 複制從此向下的10行

yy@" : 用上面所提到的那個匿名register

# 從其它程式擷取輸出 (需要外部程式)

:r!ls.exe : 讀取ls的輸出到目前位置

!!date : 讀取date的輸出 (但是會替換目前行的内容)

# 譯釋:其實你輸入了!!後,vim就自動轉換到 :.! 等待你繼續輸入

# 使用外部程式sort進行排序(sort是Unix标準指令,ls,date也是)

:%!sort -u : 使用sort程式排序整個檔案(用結果重寫檔案)

# 譯釋:%表示整個檔案的所有行

# !sort表示執行外部指令sort

# -u是sort的參數,man sort看看,這個參數的意義是合并相同的行

# u就是unique,如果兩行内容相同,則結果中隻保留一行的說

:'a,'b!sort -u : 對mark a 到mark b中間的内容進行排序

!1} sort -u : 排序目前段落 (隻能在normal模式下使用!!)

# 譯釋:!表示使用filter,1}表示filter的對象是從目前行開始向後數一段

# 段落指到空行處結束,不包括空行

# 其實你一旦輸入 !1},vim就自動計算目前段落應該到那一行(eg.+5),然後生成

# :.,.+5! 等待之後輸入sort -u,回車,完成操作

# .表示目前行,.+5當然就是目前行向後數5行

# 多文檔操作 (基礎)

# 譯注:用 :ls! 可以顯示出目前所有的buffer

:bn : 跳轉到下一個buffer

:bp : 跳轉到上一個buffer

:wn : 存盤目前檔案并跳轉到下一個(又是「超級......」,ft!)

:wp : 存盤目前檔案并跳轉到上一個

:bd : 把這個檔案從buffer清單中做掉

:bun : 卸掉buffer (關閉這個buffer的視窗但是不把它從清單中做掉)

:badd file.c : 把檔案file.c添加到buffer清單

:b 3 : 跳到第3個buffer

:b main : 跳到一個名字中包含main的buffer,例如main.c 

: (ultra,這個怎麼翻譯?:()

:sav php.html : 把目前檔案存為php.html并打開php.html

:sav! %<.bak : 換一個字尾儲存

:e! : 傳回到修改之前的檔案(修改之後沒有存盤)

:w /path/% : 把檔案存到一個地兒

:e # : 編輯标記為#的buffer(這個buffer必須含有一個可編輯的檔案)

: 用ls指令就能看到哪一個buffer有#

: %a表示目前正在編輯的buffer

: u 表示不能編輯或者已經被做掉的buffer

:e #3 : 編輯編号為3的buffer(這個buffer必須含有一個可編輯的檔案)

:rew : 回到第一個可編輯的檔案

:brew : 回到第一個buffer

:sp fred.txt : 在一個水準分割的視窗中打開檔案fred.txt

# 譯注:vs fred.txt可以實作垂直分割

:sball : 把目前所有含有可編輯檔案的buffer顯示到一個分割視窗中

: (偶該考慮把super翻譯成 進階指令 了,ft)

:map <F5> :ls<CR>:e # : 在normal模式下按F5鍵,則會顯示所有含有一個

: 可編輯檔案的buffer,然後提示你輸入buffer的序号,

: 輸入後回車,則編輯這個buffer

# 譯注:這是一個鍵盤綁定

:set hidden : 允許不儲存buffer而切換buffer (w/o=without)

# 在分割視窗中快速切換

:map <C-J> <C-W>j<C-W>_

# 譯注:原文此處有誤,前面應該加上冒号

# 這是一個鍵盤綁定,把Ctrl-J定義成切換到下一個視窗并最大化

:map <C-K> <C-W>k<C-W>_

# 指令錄制 (最佳技巧,ft)

qq #錄制到q

.. #輸入一系列複雜的指令

q #再次按q停止錄制

@q #執行q中存儲的指令

@@ #重複執行

# 編輯register/錄制

"ap #把register a中的内容貼到目前位置

.. #現在你可以修改它了

"add#删除之,重新存入register a 

@a #執行register a中的指令

# _vimrc基礎

:set incsearch : 實時比對你輸入的内容

:set wildignore=*.o,*.obj,*.bak,*.exe : tab鍵的自動完成現在會忽略這些

:set shiftwidth=4 : 現在自動縮進将是4個字元

# 譯注:一個tab位通常是8個字元

# 是以,我們還要設定 :set tabstop=4,這樣,所有的縮進都是4字元了

# emacs預設就是4字元縮進吧?

:set vb t_vb=". : 沉默方式(不要叫beep!)

# 加載windows iexplorer來浏覽(我想這隻有在windows下用gvim才能用到)

# 譯釋:nmap是做一個normal模式下的鍵盤綁定

# 這裡綁定了一個逗号指令 ,f

# :update是寫這個檔案,與:w不同,它隻有當檔案被修改了的時候才寫

# :silent别讓彈出視窗報告執行結果

# !...後面就是執行windows指令了。呵呵,去問bill gates什麼意思吧。

# 不過偶用gvim 6.1試過了,好用!

:nmap ,i :update<CR>: !start c:\progra~1\intern~1\iexplore.exe <cWORD><CR>

# 用VIM編輯ftp檔案

# 譯注:原文丢失了開頭的冒号

# cmap是指令(command)模式綁定

# 這一句就是開始編輯一個ftp遠端的檔案,ft

# 附加到一個register (就是用大寫的register名字啦!)

"a5yy #複制5行到a中

10j #下移10行

"A5yy #再添加5行到a中

[I : 顯示光标處的狹義字可以比對的行(進階指令)

# 譯注:# 可以全文查找與光标處的狹義字相比對的字,

# 這在查找函數原型和實作,或者變量使用的時候很有用

# 正常縮進

:'a,'b>>

# 譯釋:把mark a到mark b之間的内容進行兩次縮進

# 在visual模式下縮進 (無限可重複)

:vnoremap < <gv

# 譯釋::vnoremap 重定義了visual模式下 < 符号的含義

# 把它定義成 <gv

# 即:先<向外縮進,然後gv重新選擇上一次選擇了的區域

# 這樣在visual模式下就可以實作連續按<而連續縮進了

:vnoremap > >gv

# 同裡,内縮

# 查找(譯注:建議先學習正規表達式)

# 譯注:查找指令不用進入:指令模式,直接按/就可以了

# 如果沒有修飾,可以不要右邊的/

# 和smth bbs差不多啦,呵呵

/joe/e : 光标停留在比對單詞最後一個字母處

/joe/e+1 : 光标停留在比對單詞最後一個字母的下一個字母處

/joe/s : 光标停留在比對單詞第一個字母處

/^joe.*fred.*bill/ : ft,标準正規表達式

/^[A-J]\+/ : 找一個以A~J中一個字母重複兩次或以上開頭的行

/forum\(\_.\)*pent : 多行比對

/fred\_s*joe/i : 中間可以有任何空白,包括換行符\n

# 譯注:這個和perl不太一樣的哦

/fred\|joe : 比對FRED或JOE

/\<fred\>/i : 比對fred,fred必須是一個獨立的單詞,而不是子串

# 譯注:這和perl也不太一樣,perl是用\b做單詞定界符的

/\<\d\d\d\d\> : 比對4個數字

\<\d\{4}\> : 也是比對4個數字

# 在visual模式下查找

:vmap g/ y/<C-R>"<CR> : 比對選中的高亮文字

# 譯釋:vmap是在visual模式下的鍵盤映像

# 映像了g/這個指令組合

# y 把選中的高亮文字寫入匿名register "

# / 打開搜尋模式

# <C-R> 準備粘貼register

# " 粘貼了""中的内容

# <CR> 回車,執行

:vmap <silent> g/ y/<C-R>=escape(@", '\\/.*$^~[]')<CR><CR> : with spec chars

# 譯釋:@#$&^*@#%&*#$@!

# 跨行比對,\_ 表示允許比對換行符,或者說,允許比對新行

# 譯注:小心,和perl不一樣

/<!--\_p\{-}--> : 比對多行注釋

/fred\_s*joe/i : 似乎上面有了,ft

/bugs\(\_.\)*bunny : 中間可以有無數東西

:h \_ : 看看關于 \_ 的幫助

# 查找目前光标位置所在子例程/函數(subroutine/function)的聲明

:nmap gx yiw/^\(sub\<bar>function\)\s\+<C-R>"<CR>

# 譯釋:nmap 做一個normal模式下的鍵盤綁定

# y 進入複制狀态,後面需要一個motion

# 接着就用 iw 指出了這個motion,是inner word

# inner word也是狹義字<cword>,但是和 w 不同

# w 是從光标位置開始向後看

# 而inner word總是把光标移到第一個字母,進而總能得到一個完整的狹義字

# 試一試 gUw 和 gUiw 就知道差別了,呵呵。

# 在多個文檔中搜尋

:bufdo /searchstr

:argdo /searchstr

# 替換

# 譯注:替換指令需要先進入:指令模式

:%s/fred/joe/igc : 一個常見的替換指令,修飾符igc和perl中一樣意思

:%s/\r//g : 删除DOS方式的回車^M

:%s= *$== : 删除行尾空白

:'a,'bg/fred/s/dick/joe/igc : 非常有用!(ft,又來了!)

# 譯釋:'a,'b指定一個範圍:mark a ~ mark b

# g//用一個正規表達式指出了進行操作的行必須可以被fred比對

# 看後面,g//是一個全局顯示指令

# s/dick/joe/igc則對于這些滿足條件的行進行替換

# 列複制

# 譯注:@#%&^#*^%#$!

:%s= [^ ]\+$=&&= : 複制最後一列

:%s= \f\+$=&&= : 一樣的功能

:%s= \S\+$=&& : ft,還是一樣

# 反向引用,或稱記憶

:s/\(.*\):\(.*\)/\2 : \1/ : 颠倒用:分割的兩個字段

:%s/^\(.*\)\n\1/\1$/ : 删除重複行

# 非貪婪比對,\{-}

:%s/^.\{-}pdf/new.pdf/ : 隻是删除第一個pdf

# 跨越可能的多行

:%s/<!--\_.\{-}-->// : 又是删除多行注釋(咦?為什麼要說「又」呢?)

:help /\{-} : 看看關于 非貪婪數量符 的幫助

:s/fred/<c-r>a/g : 替換fred成register a中的内容,呵呵

# 寫在一行裡的複雜指令

:%s/\f\+\.gif\>/\r&\r/g | v/\.gif$/d | %s/gif/jpg/

# 譯注:就是用 | 管道啦

# 或者

:%s/suck\|buck/loopy/gc : 或者(或者需要\,ft!,|不是或者)

# ft, \不就是轉義了麼!這個和perl真是不同了!

# 調用VIM函數

:s/__date__/\=strftime("%c")/ : 插入時間串

# 處理列,替換所有在第三列中的str1

:%s:\(\(\w\+\s\+\)\{2}\)str1:\1str2:

# 交換第一列和最後一列 (共4列)

:%s:\(\w\+\)\(.*\s\+\)\(\w\+\)$:\3\2\1:

# filter all form elements into paste register

# 把所有的form元素(就是html裡面的form啦)放到register裡?

# ft, 頭疼,不解釋了

:redir @*|sil exec 'g#<\(input\|select\|textarea\|/\=form\)\>#p'|redir END

# 上面這一行不能完全顯示,最好Copy Article下去看

# 全局(global)顯示指令,就是用 :g+正規表達式

# 譯釋: :g/{pattern}/{cmd} 就是全局找到比對的行

# 然後對這些行執行指令{cmd}

:g/\<fred\>/ : 顯示所有能夠為單詞fred所比對的行

:g/<pattern>/z#.5 : 顯示内容,還有行号,呵呵

:g/<pattern>/z#.5|echo "==========" : 漂亮的顯示,ft!

# 全局指令 (其它)

:g/^\s*$/d : 删除所有空行

:g!/^dd/d : 删除不含字元串'dd'的行

:v/^dd/d : 同上

# 譯釋:v == g!,就是不比對!

:g/fred/,/joe/d : not line based (very powerfull)

:v/./.,/./-1join : 壓縮空行

:g/^$/,/./-j : 壓縮空行

:g/<input\|<form/p : 或者 要用\|

:g/^/pu _ : 把文中空行擴增一倍 (pu = put)

: 即:原來兩行間有一個空行,現在變成2個

:g/^/m0 : 按行翻轉文章 (m = move)

:g/fred/t$ : 拷貝行,從fred到檔案末尾(EOF)

:%norm jdd : 隔行删除

# 譯釋:% 指明是對所有行進行操作

# norm指出後面是normal模式的指令

# j是下移一行,dd是删除行

# incrementing numbers

:.,$g/^\d/exe "norm! \<c-a>" : 增加在BOL(beginning of line)處的數字

# 譯注:.,$ 指明指令從目前行執行到最後一行

# 如果沒有 .,$ 限定範圍,那麼g//就會對整個檔案進行操作

# exe 是執行後面的指令組合

:.,$g/^\d/exe "norm \<c-p>" : Win32下必須重定義Ctrl-A

# 儲存全局指令的結果 (注意必須使用添加模式)

:g/fred/y A : 添加所有為fred所比對的行到register a

:'a,'b g/^Error/ . w >> errors.txt

# 複制每一行,然後在複制出來的每一行兩側加上一個 print '複制出來的内容'

:g/./yank|put|-1s/'/"/g|s/.*/Print '&'/

# 全局指令和替換指令聯姻 (強大的編輯能力)

:'a,'bg/fred/s/joe/susan/gic : 可以使用反向引用來比對

:g/fred/,/joe/s/fred/joe/gic : non-line based (ultra)

:/fred/;/joe/-2,/sid/+3s/sally/alley/gIC

# 複位向到register * 和 粘貼register *

:redir @* : 複位向指令的輸出結果(最下方指令行上的結果)

: 到register * (ft,* 代表0~1,a~z,..)

:redir END : 結束複位向

# 處理粘貼

"*yy : 上面講過了,就是複制到register *中

"*p : 然後貼出來

:redir >> out.txt : 複位向到一個檔案

# 重新格式化文本

gq<CR>

gqap (a是motion p是段落(visual模式))

ggVGgq 重新格式化整個文章

# 對多個文檔實施指令

:argdo %s/foo/bar/ : 對所有:args清單中的文檔執行指令

:bufdo %s/foo/bar/

:windo %s/foo/bar/

:argdo exe '%!sort'|w! : 使用外部指令

# 指令行的一些好玩的東東

gvim -h : 激活的時候激活幫助(Win32)

vi -h 或 vim -h : 這個是unix下用

ls | gvim - : 編輯一個資料流!

gvim -o file1 file2 : 以分割視窗打開兩個檔案

# 指出打開之後執行的指令

gvim.exe -c "/main" joe.c : 打開joe.c,然後跳轉到'main'

# 對一個檔案執行多個指令

vim -c "%s/ABC/DEF/ge | update" file1.c

# 對一組檔案執行多個指令

vim -c "argdo %s/ABC/DEF/ge | update" *.c

# 自動編輯檔案 (編輯指令序列Ex commands已經包含在convert.vim中了)

vim -s "convert.vim" file.c

# 不要加載.vimrc和任何plugins (激活一個幹淨的VIM)

gvim -u NONE -U NONE -N

# GVIM 不同的地方

gvim -d file1 file2 : vimdiff (比較不同)

dp : 把光标處的不同放到另一個檔案

do : 在光标處從另一個檔案取得不同

# Vim陷阱

# 在vim的正規表達式中, + 和 | 都必須加轉義符 \

# 小心,這和perl不一樣!

/fred\+/ : 比對fred或freddy但是不比對free

# \v ,或叫做very magic (通常都是這麼叫)可以取消轉義符

/codes\(\n\|\s\)*where : 普通的正規表達式

/\vcodes(\n|\s)*where : very magic,| 不用加 \ 了!

# 把東西送到指令行/搜尋行 (SUPER:偶不再翻譯這種歎詞了)

<C-R><C-W> : 送一個狹義詞

<C-R><C-A> : 送一個廣義詞

<C-R>- : 送一個小型删除寄存器register

<C-R>[0-9a-z] : 送一個命名寄存器register

<C-R>% : 送檔案名過去 (#也行)

# 操作寄存器

:let @a=@_ : 清除register a

:let @*=@a : 寄存器指派

:map <f11> "qyy:let @q=@q."zzz"

# 譯注:猜猜這個無聊的綁定是什麼意思?

# 關于幫助的幫助

:h quickref : 翻到VIM Quick Reference頁(有用!)

:h tips : Vim自己的tips

:h visual<C-D><tab> : 得到一個關于visual關鍵詞的幫助清單

: 然後用tab鍵去選擇

:h ctrl<C-D> : 顯示所有關于Ctrl的幫助

:h :r : :ex冒号指令

:h CTRL-R : 普通模式指令

:h \r : \r在正規表達式中是什麼意思呢?

:h i_CTRL-R : insert模式下的Ctrl-R

:h c_CTRL-R : 指令行(command-line)模式下的Ctrl-R

:h v_CTRL-V : visual模式下的Ctrl-V

:h tutor : VIM 指南

gvim -h : 關于 VIM 指令的幫助

vi/vim -h

<C-S>T : Control Shift T go backwards in help

: 偶不清楚有什麼用:(

# 選項設定在哪裡?

:scriptnames : 列出所有加載的 plugins, _vimrcs

:verbose set history : 顯示history的值并指出設定檔案的位置

# 制作你自己的VIM幫助

:helptags /vim/vim61/doc : 重建 /doc 中所有的 *.txt 幫助檔案

:help add-local-help

# 用外部程式來運作程式 (例如 perl :)

map <f2> :w<CR>:!perl -c %<CR>

# 譯釋::w<CR>寫檔案

# :!perl -c %<CR>用perl來運作目前檔案

# 目前檔案必須有檔案名!

# 插入DOS換行符

:%s/nubian/<C-V><C-M>&/g : Ctrl-V是一種轉義,它說要解釋<C-M>

:%s/nubian/<C-Q><C-M>&/g : 對于Win32應該這樣

:%s/nubian/^M&/g : 你看到的^M是一個字元

:%s/nubian/\r&/g : 更好的形式

# 把最後一個指令貼到目前位置

i<c-r>:

# 把最後一個搜尋指令貼到目前位置

i<c-r>/

# 譯釋:i是進入insert模式,

# Ctrl-r是開啟插入模式下register的引用

# :和/分别引用了兩個register的内容

# 更多的完成功能

<C-X><C-F> :插入目前目錄下的一個檔案名到目前位置

# 在insert模式下使用

# 然後用 Ctrl-P/Ctrl-N 翻頁

# 替換一個visual區域

# 選擇一個區域,然後輸入 :s/Emacs/Vim/ 等等,vim會自動進入:模式

:'<,'>s/Emacs/Vim/g : 前面的'<,'>是vim自動添加的

# 在檔案中插入行号(不是顯示行号,是插入!)

:g/^/exec "s/^/".strpart(line(".")." ", 0, 4)

# 用VIM的方式來編号行

:set number :顯示行号

:set nonu :取消顯示

:%s/^/\=strpart(line('.')." ",0,&ts)

#從任意行開始編号(需要perl,嘿嘿)

:'a,'b!perl -pne 'BEGIN{$a=223} substr($_,2,0)=$a++'

#似乎有點小問題,你試試看:)

qqmnYP`n^Aq : 記錄到q 然後用 @q 重複

#似乎不能工作,你試試看:)

# 遞增已存在數字到檔案末

:.,$g/^\d/exe "normal! \<c-a>"

# 進階遞增,看:

<a href="http://vim.sourceforge.net/tip_view.php?tip_id=150">http://vim.sourceforge.net/tip_view.php?tip_id=150</a>

# 進階遞增 ("真的很有用",ft)

" 把下面幾句放到 _vimrc #vimrc腳本用 " 做行注釋符

let g:I=0

function! INC(increment)

let g:I =g:I + a:increment

return g:I

endfunction

" 例如從mark a 到mark b 遞增,從223開始,步長為5

:let I=223

:'a,'bs/$/\=INC(5)/

" (原文:create a map for INC) 

" 但是cab是清楚指令行縮寫啊?怎麼回事?

cab viminc :let I=223 \| 'a,'bs/$/\=INC(5)/

# 加密(小心使用,不要忘了密碼)

:X : 然後vim會提示你輸入密碼

:h :X

# modeline (make a file readonly etc) must be in first/last 5 lines

# 不會用,不翻了

// vim:noai:ts=2:sw=4:readonly:

:h modeline

# Creating your own GUI Toolbar entry

# 對于text模式下的vim沒用,不翻了

amenu Modeline.Insert\ a\ VIM\ modeline &lt;Esc&gt;&lt;Esc&gt;ggOvim:ff=unix ts=4 ss=4&lt;CR&gt;v

# 一個儲存目前光标下的狹義字到一個檔案的函數

function! SaveWord() "這裡用!是強制覆寫以前的定義

normal yiw

map ,p :call SaveWord() #使用該函數的一個例子

# 删除重複行的函數

function! Del()

if getline(".") == getline(line(".") - 1)

norm dd

endif

:g/^/ call Del() #使用該函數的一個例子

# 雙位元組編碼 (non alpha-numerics)

:digraphs : 顯示編碼表

:h dig : 幫助

i&lt;C-K&gt;e' : 輸入 é

i&lt;C-V&gt;233 : 輸入 é (Unix)

i&lt;C-Q&gt;233 : 輸入 é (Win32)

ga : 檢視字元的hex值

# 檔案名自動完成 (例如 main_c.c)

:e main_&lt;tab&gt; : tab 鍵完成

gf : 打開光标處廣義字命名的檔案 (normal模式)

main_&lt;C-X&gt;&lt;C-F&gt; : 檔案名自動完成(insert模式)

# Vim複雜使用

# 交換兩個單詞

:%s/\&lt;\(on\|off\)\&gt;/\=strpart("offon", 3 * ("off" == submatch(0)), 3)/g

# 把text檔案轉換成html檔案(oh,ft)

:runtime! syntax/2html.vim : 轉換 txt 成 html

:h 2html : 看看幫助

# VIM 有一個内部自帶的 grep 指令

:grep some_keyword *.c : 得到一個包含some_keyword的c檔案名清單

:cn : 去下一個出現的位置

# 強制無字尾檔案的文法着色方式 .pl

:set syntax=perl

# 取消文法着色

:set syntax off

# 改變色彩主題 (在~vim/vim??/colors中的任何檔案)

:colorscheme blue

:set noma (non modifiable) : 防止修改

:set ro (Read Only) : 隻讀保護

# Sessions (打開一系列檔案)

gvim file1.c file2.c lib/lib.h lib/lib2.h :在"session"中加載一系列檔案

:mksession : 生成一個Session檔案 (預設是Session.vim)

:q

gvim -S Session.vim : 重新讀取一個session,也就讀取了所有檔案,ft

# 标記(tags) (跳轉到subroutines/functions)

taglist.vim : 最流行的插件

:Tlist : 顯示Tags (functions的清單)

&lt;C-]&gt; : 跳轉到光标處的function

: 這個鍵 Ctrl-] 和vim幫助中是一樣的

# Just Another Vim Hacker JAVH

# Juat Another Perl Hacker JAPH,嘿嘿

vim -c ":%s/^/WhfgTNabgureRIvzSUnpxre/|:%s/[R-T]/ /Ig|:normal ggVGg?"

# 譯釋:呵呵,誰來解釋一下吧!

# 其實不過是在激活vim的時候執行了一個指令

# 先寫入了 Just Another Vim Hacker 的rot13編碼

# 然後再譯碼

終于翻完了,呵呵。好累啊!

__END__