技术标签: vim中文手册
目录
这篇文章纯粹是我个人在学习使用vi编辑器过程中经验的积累,其中语言文字上面也许会有些错误,希望读者发现之后能够帮我纠正,在此先谢了。
这里的每个命令都经过我亲身的实践,关于vi编辑器系统一些的中文资料不是很多,所以学习vi编辑器对大家来说有一定的难度,我的愿望是大家能够花费尽可能短的时间,掌握vi编辑器的使用方法。学习并实践完本文之后,相信你最起码能够在vi的“海洋”中自由地翱翔。如果你仅仅是为了临时使用这个工具来临时做一些事情,那么本文也适合你,你只需要看本前言中的【最基本的使用】一节即可。如果有人转载,希望您能注明出处和作者;如果将本文用于商业行为,希望您能先通知我;希望大家能够互相体谅,尊重对方的劳动成果。
vi就是linux命令行下的最著名的编辑器之一,(编辑器就是类似windows记事本的功能,不过vi功能比记事本强大无限倍!^_^)。
没有明确的定义,这里给出一些经验性的概括:
本文主要介绍Vim编辑器,Emacs的介绍放在其它之处
目前我们实际使用的都是Vim,它其实是vi的改进版本之一,是最流行的改进版本,所以现在所说的Vi基本上就是Vim了
Vim能够处理的事情很多,前面说了那么多空话,为避免有广告之嫌,这里列出其中一些常用的功能应用:
等等……
这里的比较主要是针对与它的“对手”Emacs而言,前面众多说法中,有一种可以这样解释:在Linux/Unix界,有三种编辑器:一种是Emacs,一种是Vim,还有一种是除此之外的编辑器,由此可见Vim在编辑器领域的地位。
Vim与Emacs,两者各有千秋,下面只列出其中少许
等等……
其实,Vim更算是一款编辑器,而Emacs则像是隐藏在编辑器下的操作系统。
有人做过这样的比喻,Vim是编辑器之神,Emacs是神之编辑器。
两者除各自擅长之处外,又各自在对方擅长的领域表现优异,令其它类编辑器“无可乘之机”,也另对方不敢有丝毫“松懈”。
本文并无意加入Vim和Emacs的圣战中来;因讲述的是Vim的使用,所以针对其特点进行叙述;相应地Emacs也有它的特点,在讲述Emacs之时也会相应提到。
一般使用过两者的人,可能会有如下的感觉:
还有许多,这里也不过多叙述,为避免卷入圣战,还是需要做一点补充:当然,若不频繁切换自己的环境,或者能找到一种方式稳定在同一环境下工作的话,Emacs迟早也同样能做到甚至超越这些方面(记得有一款Emacs插件叫"evil",作用是将vim的功能包含到Emacs中来,可见这款插件的意图是多么的邪恶^_^)。
总之,使用工具的方式,决定工具的价值。
Vim与Emacs其实也有许多共通之处,这里只给出我们最容易遇见和理解的两条:
历史上两者的阵营之间爆发过多次“圣战”,涉及的方面太多,这里不一一列举,在实用的原则上,这里给出一点建议: 对两者的选择,应当建立在对它们的了解之上
特殊按键表示:
Space: <SPC>
Ctrl: <CTRL>或<C>
Alt: <ALT>或<M>
Esc: <ESC>(注意,Emacs也将Esc键归为<M>)
Shift: <SHIFT>或<S>
Tab: <Tab>
Enter: <Enter>(有些时候为<RET>或<CR>)
BackSpace:<<BS>(注意,Emacs上表示为<DEL>,Emacs上<DEL>不是Delete按键)
Delete:<Del>
组合键的表示:
<Esc>: Escape key
<C-G>: CTRL-G
<Up>: cursor up key
<C-LeftMouse>: Control- left mouse click
<S-F11>: Shifted function key 11
<M-a>: Meta- a ('a' with bit 8 set)
<M-A>: Meta- A ('A' with bit 8 set)
<t_kd>: "kd" termcap entry (cursor down key)
更多内容可以打开Vim并输入=:help keycode=,参考其帮助手册给出的Key表示。
在没有歧义的情况下,可以使用任何方式表示。
Vim具有多种模式,后面会详述,初学时,我们最好能理解其中两种最常见的模式:
总结起来,在本文中,“插入模式”=“输入模式”=“编辑模式”、“指令模式”=“命令模式”、“行命令模式”是特殊的指令模式。
这里提供了使用vi得最基本的操作,能够实现基本的编辑目的。
如果你肯花几分钟把这里的内容都实践一下,那么至少能够独立地在Vim中朝你想要得方向“前进”。
如果你不想学习,也可以把它当作一个“便签”,现查现用。
这里,开始输入v使vi临时进入了一个"选择模式",输入方向键可以选择,输入y将选择的内容复制剪切板。
文章浏览阅读9.7k次,点赞2次,收藏7次。感觉拖了好久,今天将Wait接口的总结补上,顺便把SearchCondition也捎带结了。 直接上图。Wait方法含义:查看查询条件是否符合,若符合,则返回结果。若不符合,则继续等待,直至超时。 返回结果可能为UIObject2对象或者UIObject2对象列表,或者布尔类型。其中,传参SearchCondition是一个抽象类,若想获取其实体对象,需要调用Until工具类。 该类提供了4个_uidevice wait
文章浏览阅读8.1k次,点赞2次,收藏4次。SpringBoot——入门案例之“Hello SpringBoot“_hello springboot
文章浏览阅读1.2k次。我们的口号是:人生不设限!! 学习规划:继续上篇 《Docker入门》https://www.cnblogs.com/dk1024/p/13121389.html 继续讲解:一、容器数据卷1、什么是容器数据卷:Docker是将应用和环境打包成一个镜像,发布到服务器,这个跑起来的容器如果不小心删除掉,呢么数据就会全部丢失,尤其是Mysql之类的容器,name现在就有一个需求,数..._avtxt
文章浏览阅读1.2k次,点赞2次,收藏15次。XML 简介、编写规范、Java 解析 XML(DOM 解析 XML、DOM4J 解析 XML)……关于 Java 高级特性之 XML 比较详细、系统的整理。_java xml示“收藏信息.xml”文件中收藏的手机品牌和型号
文章浏览阅读6.4k次。1、统合综效的基本心态是:如果一位具有相当聪明才智的人跟我意见不同,那么对方的主张必定有我尚未体会的奥妙,值得加以了解。2、与人合作最重要的是,重视不同个体的不同心理、情绪与智能,以及个人眼中所见到的不同世界。与所见略同的人沟通,益处不大,要有分歧才有收获。3、我以圣者的期望自勉:对关键事务——团结,对重大事务——求变,对所有事务——宽大。——美国前总统乔治.布什(George Bush)_高效能人士的七个习惯 第九章统合综效
文章浏览阅读846次。笑脸工具,用于坐标转换。_坐标转换工具
文章浏览阅读36次。在本文中,我们介绍了基于法向量的点云分割方法,并提供了Matlab实现代码。该方法通过分析点云中的法向量信息,可以有效地划分点云数据集,识别出不同的表面和物体。基于法向量的点云分割方法将点云中的每个点的法向量信息作为关键特征来进行分割。基于法向量的点云分割方法将点云中的每个点的法向量信息作为关键特征来进行分割。该方法通过分析点云中的法向量信息,可以有效地划分点云数据集,识别出不同的表面和物体。点云分割是计算机视觉和模式识别领域的重要任务之一,它的目标是将点云数据集划分为具有不同属性或语义的子集。
文章浏览阅读630次。C#调用OpenVINOTM部署Al模型项目开发项目,简称OpenVinoSharp,这是一个示例项目,该项目实现在C#编程语言下调用Intel推出的 OpenVINO 工具套件,进行深度学习等Al项目在C#框架下的部署。该项目由C++语言编写OpenVINO API接口,并在C#语言下实现应用。..._vs2022如何安装openvino c# api
文章浏览阅读2.4k次,点赞2次,收藏4次。Flyway对数据库进行版本管理主要由Metadata表(默认是flyway_schema_history)和6种命令完成,Metadata主要用于记录每次执行的脚本和version等信息,下面一一介绍。Metadata表(flyway_schema_history)Flyway中最核心的就是用于记录所有版本执行结果和状态的Metadata表,在Flyway首次启动时会创建默认名为flywa..._flyway命令
文章浏览阅读1.8k次,点赞2次,收藏7次。Crash问题分析定位:通过Log文件夹下全局搜am_crash,此时会把log文件下下所有的包含am_crash的行显示出来一.导致Android Crash 问题的主要类型4)Other由上图可见,在APP层面我们出现并能解决的BUG 集中在App Crash 和System crash 层;_android crash
文章浏览阅读1.1k次。这篇文章主要介绍了php使用curl获取https请求的方法,涉及curl针对https请求的操作技巧,非常具有实用价值,需要的朋友可以参考下本文实例讲述了php使用curl获取https请求的方法。分享给大家供大家参考。具体分析如下:今日在做一个项目,需要curl获取第三方的API,对方的API是https方式的。之前使用curl能获取http请求,但今天获取https请求时,出现了以下的错误提..._curl 访问 api ssl
文章浏览阅读1.1k次,点赞23次,收藏21次。1.2数据存储采用分片存储方式,整个redis集群有16384个哈希槽,集群中的每个节点负责一部分哈希槽,现在集群中三个主节点,就会把这些哈希槽平均分配给三个主节点,即节点A存储的哈希槽范围是:0 – 5500,节点B存储的哈希槽范围是:5501 – 11000,节点C存储的哈希槽范围是:11001 – 16384,当需要扩容主节点时会将ABC的哈希槽数据提取一部分到新的主节点D上,若是删除主节点A,就需要先将A中的哈希槽数据转移到BC节点上再进行删除。因为redis是用c实现的,所有要进行编译操作;_redis cluster 搭建