# 基礎
----------------------------------------
* # 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 <Esc><Esc>ggOvim:ff=unix ts=4 ss=4<CR>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<C-K>e' : 輸入 é
i<C-V>233 : 輸入 é (Unix)
i<C-Q>233 : 輸入 é (Win32)
ga : 檢視字元的hex值
# 檔案名自動完成 (例如 main_c.c)
:e main_<tab> : tab 鍵完成
gf : 打開光标處廣義字命名的檔案 (normal模式)
main_<C-X><C-F> : 檔案名自動完成(insert模式)
# Vim複雜使用
# 交換兩個單詞
:%s/\<\(on\|off\)\>/\=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的清單)
<C-]> : 跳轉到光标處的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__