Vimdiff 使用
各种 IDE 大行其道的同时,传统的命令行工具以其短小精悍,随手可得的特点仍有很大的生存空间,这篇短文介绍了一个文本比较和合并的小工具:vimdiff。希望能对在 Unix/Linux 系统上进行开发的朋友有所帮助。
源程序文件(通常是纯文本文件)比较和合并工具一直是软件开发过程中比较重要的组成部分。现在市场上很多功能很强大的专用比较和合并工具,比如 BeyondCompare;很多IDE 或者软件配置管理系统,比如Eclipse, Rational ClearCase都提供了内建的功能来支持文件的比较和合并。
当远程工作在Unix/Linux平台上的时候,恐怕最简单而且到处存在的就是命令行工具,比如diff。可惜diff的功能有限,使用起来也不是很方便。作为命令行的比较工具,我们仍然希望能拥有简单明了的界面,可以使我们能够对比较结果一目了然;我们还希望能够在比较出来的多处差异之间快速定位,希望能够很容易的进行文件合并……。而Vim提供的diff模式,通常称作vimdiff,就是这样一个能满足所有这些需求,甚至能够提供更多的强力工具。在最近的工作中,因为需要做很多的文件比较和合并的工作,因此对Vimdiff的使用做了一个简单的总结。我们先来看看vimdiff的基本使用。
启动方法
首先保证系统中的diff命令是可用的。Vim的diff模式是依赖于diff命令的。Vimdiff的基本用法就是:
# vimdiff FILE_LEFT FILE_RIGHT或者
# vim -d FILE_LEFT FILE_RIGHT图一就是vimdiff命令的执行结果的画面。

从上图我们可以看到一个清晰的比较结果。屏幕被垂直分割,左右两侧分别显示被比较的两个文件。两个文件中连续的相同的行被折叠了起来,以便使用者能把注意力集中在两个文件的差异上。只在某一文件中存在的行的背景色被设置为蓝色,而在另一文件中的对应位置被显示为绿色。两个文件中都存在,但是包含差异的行显示为粉色背景,引起差异的文字用红色背景加以突出。
如果在退出的时候不希望保存任何操作的结果:
:qa! (force to quit all)上下文的展开和查看
比较和合并文件的时候经常需要结合上下文来确定最终要采取的操作。Vimdiff 缺省是会把不同之处上下各 6 行的文本都显示出来以供参考。其他的相同的文本行被自动折叠。如果希望修改缺省的上下文行数,可以这样设置:
:set diffopt=context:3可以用简单的折叠命令来临时展开被折叠的相同的文本行:
zo (folding open,之所以用z这个字母,是因为它看上去比较像折叠着的纸)然后可以用下列命令来重新折叠:
zc (folding close)下图是设置上下文为3行,并展开了部分相同文本的vimdiff屏幕:

结论
在无法使用图形化的比较工具的时候,或者在需要快速比较和合并少量文件的时候,Vimdiff是最好的选择。
除了用这种方法启动vim的diff模式之外,我们还可以用分割窗口命令来启动diff模式:
# vim FILE_LEFT然后在vim的ex模式(也就是"冒号"模式)下输入:
:vertical diffsplit FILE_RIGHT也可以达到同样的效果。如果希望交换两个窗口的位置,或者希望改变窗口的分割方式,可以使用下列命令:
1. Ctrl-w K(把当前窗口移到最上边)
2. Ctrl-w H(把当前窗口移到最左边)
3. Ctrl-w J(把当前窗口移到最下边)
4. Ctrl-w L(把当前窗口移到最右边)
其中1和3两个操作会把窗口改成水平分割方式。
光标移动
接下来试试在行间移动光标,可以看到左右两侧的屏幕滚动是同步的。这是因为"scrollbind"选项被设置了的结果,vim会尽力保证两侧文件的对齐。如果不想要这个特性,可以设置:
:set noscrollbind可以使用快捷键在各个差异点之间快速移动。跳转到下一个差异点:
]c反向跳转是:
[c如果在命令前加上数字的话,可以跳过一个或数个差异点,从而实现跳的更远。比如如果在位于第一个差异点的行输入"2]c",将越过下一个差异点,跳转到第三个差异点。
文件合并
文件比较的最终目的之一就是合并,以消除差异。如果希望把一个差异点中当前文件的内容复制到另一个文件里,可以使用命令
dp (diff "put")如果希望把另一个文件的内容复制到当前行中,可以使用命令
do (diff "get",之所以不用dg,是因为dg已经被另一个命令占用了)如果希望手工修改某一行,可以使用通常的vim操作。如果希望在两个文件之间来回跳转,可以用下列命令序列:
Ctrl-w, w在修改一个或两个文件之后,vimdiff会试图自动来重新比较文件,来实时反映比较结果。但是也会有处理失败的情况,这个时候需要手工来刷新比较结果:
:diffupdate如果希望撤销修改,可以和平常用vim编辑一样,直接
<ESC>, u但是要注意一定要将光标移动到需要撤销修改的文件窗口中。
同时操作两个文件
在比较和合并告一段落之后,可以用下列命令对两个文件同时进行操作。比如同时退出:
:qa (quit all)如果希望保存全部文件:
:wa (write all)或者是两者的合并命令,保存全部文件,然后退出:
上一篇:使用 Git 管理源代码 下一篇:Apache和Subversion 搭建安全CVS
相关文章
- 深入学习Xen新起点 全面介绍Xen虚拟机
- 在Linux上实现单臂路由器功能
- 改善Linux内核和可伸缩性适应企业环境
- busybox简介及使用
- Linux编程之序列化存储Python对象
- 应用2.6内核超线程模式
- Linux内核: 修改TCP/IP调优参数
- MPPE加密VPN服务器详解
- 奇妙的 sys 请求
- 关于Linux操作系统进程操作(ps)命令简介
- Linux系统在嵌入式系统上的实践和探讨
- Apache和Subversion 搭建安全CVS
- Linux操作系统硬件稳定性指南
- X服务器配置指南
- 基于Linux操作系统内核汉化大揭秘
- 基于Linux的移动电话开发技术及前景
- 我的六个操作系统安装方法及其应用
- Linux系统内核中的Device Mapper机制
- 玩转Ubuntu Linux之加密文件系统篇
- LINUX技巧四则
站长推荐
- 对CableModem双向传输技术探讨(三)
- MPEG—4 系统浅谈(一)
- 对CableModem双向传输技术探讨(一)
- MPEG-4的广泛应用
- 广电全国骨干网数据平台技术介绍(二)
- 广电全国骨干网数据平台技术介绍(一)
- 流媒体技术分析及其在新闻网站的应用
- 基于互联网的嵌入式远程监控系统的研究
- 网络电视一种新的媒体
- 交互电视——不仅仅是机顶盒
- 智能视频监控网:宽带视频业务发展新契机
- 电信VOD视频点播系统
- Edgewater公司:VoIP的QoS及安全性解决方案
- 虚拟电话网增值服务系统解决方案
- 方正视频点播系统解决方案
- 构建多点视频会议系统
- 可视电话的关键技术及单机解决方案
- 视频会议解决方案
- UniMaster™信令监测系统
- 黑龙江国税系统IP语音网络方案
最近更新
- Linux操作系统下光盘刻录实战
- 打造完美Linux系统:疑难杂症的解决
- Linux+Apache实现用户身份认证
- Redflag Linux Server 4.1架设Sybase
- Linux下Apache并发连接数和带宽控制
- 浅析Linux系统帐户的管理和审计
- 用Ndiswrapper在Linux中配置无线网卡
- Red Hat9.0与XP组成双系统
- Debian服务器设置入门教程之二
- Linux环境下黑客常用嗅探器分析
- Linux系统文件系统优化及磁盘检查
- Linux 的魅力: MediaMVP 内幕
- Linux系统下解析Elf文件DT_RPATH后门
- newusers和chpasswd的用法
- redhat9终端下更改时区
- Gentoo另类FAQ集锦
- 如何实现Windows与Linux文件系统共享
- fsck-Linux文件系统检查工具介绍
- 远程安装ArchLinux(Remote ArchLinux Install)
- 2.4.22-1内核架设openmosix集群
