vim实用指南(9)vimdiff好用的可视化文本对比工具
各種 IDE 大行其道的同時(shí),傳統(tǒng)的命令行工具以其短小精悍,隨手可得的特點(diǎn)仍有很大的生存空間,這篇短文介紹了一個(gè)文本比較和合并的小工具:vimdiff。希望能對(duì)在 Unix/Linux 系統(tǒng)上進(jìn)行開發(fā)的朋友有所幫助。
源程序文件(通常是純文本文件)比較和合并工具一直是軟件開發(fā)過程中比較重要的組成部分。現(xiàn)在市場(chǎng)上很多功能很強(qiáng)大的專用比較和合并工具,比如 BeyondCompare;很多IDE 或者軟件配置管理系統(tǒng),比如Eclipse, Rational ClearCase都提供了內(nèi)建的功能來支持文件的比較和合并。
當(dāng)遠(yuǎn)程工作在Unix/Linux平臺(tái)上的時(shí)候,恐怕最簡(jiǎn)單而且到處存在的就是命令行工具,比如diff。可惜diff的功能有限,使用起來也不是很方便。作為命令行的比較工具,我們?nèi)匀幌M軗碛泻?jiǎn)單明了的界面,可以使我們能夠?qū)Ρ容^結(jié)果一目了然;我們還希望能夠在比較出來的多處差異之間快速定位,希望能夠很容易的進(jìn)行文件合并……。而Vim提供的diff模式,通常稱作vimdiff,就是這樣一個(gè)能滿足所有這些需求,甚至能夠提供更多的強(qiáng)力工具。在最近的工作中,因?yàn)樾枰龊芏嗟奈募容^和合并的工作,因此對(duì)Vimdiff的使用做了一個(gè)簡(jiǎn)單的總結(jié)。我們先來看看vimdiff的基本使用。
啟動(dòng)方法
首先保證系統(tǒng)中的diff命令是可用的。Vim的diff模式是依賴于diff命令的。Vimdiff的基本用法就是:
# vimdiff FILE_LEFT FILE_RIGHT或者
# vim -d FILE_LEFT FILE_RIGHT圖一就是vimdiff命令的執(zhí)行結(jié)果的畫面。
從上圖我們可以看到一個(gè)清晰的比較結(jié)果。屏幕被垂直分割,左右兩側(cè)分別顯示被比較的兩個(gè)文件。
- 兩個(gè)文件中連續(xù)的相同的行被折疊了起來,以便使用者能把注意力集中在兩個(gè)文件的差異上。
- 只在某一文件中存在的行的背景色被設(shè)置為藍(lán)色,而在另一文件中的對(duì)應(yīng)位置被顯示為青色且有虛線。
- 兩個(gè)文件中都存在,但是包含差異的行顯示為粉色背景,引起差異的文字用紅色背景加以突出。
除了用這種方法啟動(dòng)vim的diff模式之外,我們還可以用分割窗口命令來啟動(dòng)diff模式:
# vim FILE_LEFT然后在vim的ex模式(也就是"冒號(hào)"模式)下輸入:
:vertical diffsplit FILE_RIGHT也可以達(dá)到同樣的效果。如果希望交換兩個(gè)窗口的位置,或者希望改變窗口的分割方式,可以使用下列命令:
\1. Ctrl-w K(把當(dāng)前窗口移到最上邊)
\2. Ctrl-w H(把當(dāng)前窗口移到最左邊)
\3. Ctrl-w J(把當(dāng)前窗口移到最下邊)
\4. Ctrl-w L(把當(dāng)前窗口移到最右邊)
其中1和3兩個(gè)操作會(huì)把窗口改成水平分割方式。
光標(biāo)移動(dòng)
接下來試試在行間移動(dòng)光標(biāo),可以看到左右兩側(cè)的屏幕滾動(dòng)是同步的。這是因?yàn)?#34;scrollbind"選項(xiàng)被設(shè)置了的結(jié)果,vim會(huì)盡力保證兩側(cè)文件的對(duì)齊。如果不想要這個(gè)特性,可以設(shè)置:
:set noscrollbind可以使用快捷鍵在各個(gè)差異點(diǎn)之間快速移動(dòng)。跳轉(zhuǎn)到下一個(gè)差異點(diǎn):
]c反向跳轉(zhuǎn)是:
[c如果在命令前加上數(shù)字的話,可以跳過一個(gè)或數(shù)個(gè)差異點(diǎn),從而實(shí)現(xiàn)跳的更遠(yuǎn)。比如如果在位于第一個(gè)差異點(diǎn)的行輸入"2]c",將越過下一個(gè)差異點(diǎn),跳轉(zhuǎn)到第三個(gè)差異點(diǎn)。
文件合并
文件比較的最終目的之一就是合并,以消除差異。如果希望把一個(gè)差異點(diǎn)中當(dāng)前文件的內(nèi)容復(fù)制到另一個(gè)文件里,可以使用命令
dp (diff "put")如果希望把另一個(gè)文件的內(nèi)容復(fù)制到當(dāng)前行中,可以使用命令
do (diff "get",之所以不用dg,是因?yàn)閐g已經(jīng)被另一個(gè)命令占用了)如果希望手工修改某一行,可以使用通常的vim操作。如果希望在兩個(gè)文件之間來回跳轉(zhuǎn),可以用下列命令序列:
Ctrl-w, w在修改一個(gè)或兩個(gè)文件之后,vimdiff會(huì)試圖自動(dòng)來重新比較文件,來實(shí)時(shí)反映比較結(jié)果。但是也會(huì)有處理失敗的情況,這個(gè)時(shí)候需要手工來刷新比較結(jié)果:
:diffupdate如果希望撤銷修改,可以和平常用vim編輯一樣,直接
<ESC>, u但是要注意一定要將光標(biāo)移動(dòng)到需要撤銷修改的文件窗口中。
同時(shí)操作兩個(gè)文件
在比較和合并告一段落之后,可以用下列命令對(duì)兩個(gè)文件同時(shí)進(jìn)行操作。比如同時(shí)退出:
:qa (quit all)如果希望保存全部文件:
:wa (write all)或者是兩者的合并命令,保存全部文件,然后退出:
:wqa (write, then quit all)如果在退出的時(shí)候不希望保存任何操作的結(jié)果:
:qa! (force to quit all)上下文的展開和查看
比較和合并文件的時(shí)候經(jīng)常需要結(jié)合上下文來確定最終要采取的操作。Vimdiff 缺省是會(huì)把不同之處上下各 6 行的文本都顯示出來以供參考。其他的相同的文本行被自動(dòng)折疊。如果希望修改缺省的上下文行數(shù),可以這樣設(shè)置:
:set diffopt=context:3可以用簡(jiǎn)單的折疊命令來臨時(shí)展開被折疊的相同的文本行:
zo (folding open,之所以用z這個(gè)字母,是因?yàn)樗瓷先ケ容^像折疊著的紙)然后可以用下列命令來重新折疊:
zc (folding close)下圖是設(shè)置上下文為3行,并展開了部分相同文本的vimdiff屏幕:
結(jié)論
在無法使用圖形化的比較工具的時(shí)候,或者在需要快速比較和合并少量文件的時(shí)候,Vimdiff是最好的選擇。
總結(jié)
以上是生活随笔為你收集整理的vim实用指南(9)vimdiff好用的可视化文本对比工具的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: python vimdiff_技巧:Vi
- 下一篇: 端午杂谈