普通模式:

h j k l 分别是左下上右方式移动;

:w 保存修改

:q 推出

:wq 保存修改并退出

:q! 放弃修改强制推出

x 删除光标所在位置字符

i 在光标所以位置插入字符

删除类命令:

dw 从光标处删除至一个单字/单词的末尾

d$ 从当前光标删除到行末

d的简短对象列表

w - 从当前光标当前位置直到单字/单词末尾,包括空格。
    e - 从当前光标当前位置知道单字/单词末尾,包括*不*包括空格。

$ - 从当前光标当前位置知道行末。
dd 删除光标所在的整行

2dd 删除光标所在行及下一行,数字是连续删除几行,默认是1行,3dd是连续删除3行

撤销类命令:

u 撤销修改,类似与Ctrl+z

U 回到该行原始状态

Ctrl+r 执行回复命令,撤销掉撤销命令

置入类命令:

dd 删除后,删除的内容会移到缓冲区

p 移到想置入位置的上方,再按p键粘贴

替换类命令:

r 光标位置字符,按r后再按想要替换的字符

更改类命令:

cw 改变一个单字/单词的部分或全部

c$,ce 前面小列表有提到$和e,c是命令 w、$和e都是对象

定位及文件状态:

Ctrl+g 页面最低不出现一个状态信息行,显示的内容是当前百年及的文件名和文件的总行书

G 当前光标直接跳转到文件最后一行

#+G 返回当时按指定行号的行,#代表行号,类似 :行号,注意:输入行号时,行号不会在屏幕上显示出来

搜索类命令:

/+ 字符串 找到搜索的字符串

然后

n 向上查找相同的字符

N 向下查找相同的字符

?代替/ 逆向查找字符串

配对括号的查找:

% 光标移至括号处,按%可以查找配对的括号)、]、}

修正错误的方法之一

:s/old/new/           替换一行内第一个匹配的字符串

:s/old/new/g         替换当前行所有匹配的字符串

:#,#s/old/new/g    #代表行号,替换两行之间每个匹配的字符串

:%s/old/new/g     全局替换,替换整个文件中的每个匹配的字符串

在 VIM 內執行外部命令的方法:

! 输入:!然后紧随输入一个外部命令可以执行该外部命令

步骤:

1.按下我们所熟悉的:命令设置光标到屏幕底部。这样就可以输入命令了。

2.接着输入感叹号!这个字符,这样就允许你执行外部的shell命令了。

3.现在以ls命令为例。

:!ls<回车>  该命令就会列举出你当前目录的内容,效果同你在命令行提示符下输入ls命令的结果一样。

:!dir<回车>
---> 提示︰ 所有的外部命令都可以以这种方式执行。
---> 提示︰ 所有的 : 命令都必须以 <回车> 告终。

关于保存文件的更多信息

:w filiename  其中filename是一个尚未存在的文件,用来保存整个文件。

:!rm filename 删除文件

一个具有选择性的保存命令

:#,#w filename #是行号,作用是将两行之间的内容保存到filename这个新创建的文件中。

提取和合并文件

:r filename

打开类命令:

o 在光标下方打开新的一行并进入插入模式;

O 在光标上方打开新的一行并进入插入模式;

光标后插入命令:

a 光标后插入文本

A 行末后插入文本

另外一个置换命令的版本

R 可连续替换多个字符

设置类命令:

:set xxx 可以设置XXX选项

例如:set ic 搜索时忽略大小写

使用在线帮助系统 

Vim 拥有一个细致全面的在线帮助系统。要启动该帮助系统,请选择如下三种方
法之一∶
- 按下 <HELP> 键 (如果键盘上有的话)
- 按下 <F1> 键 (如果键盘上有的话)
- 输入 :help <回车>

输入 :q <回车> 可以关闭帮助窗口。

提供一个正确的参数给":help"命令,您可以找到关于该主题的帮助。请试验以
下参数(可别忘了按回车键哦。:)∶

:help w <回车>
:help c_<T <回车>
:help insert-index <回车>
:help user-manual <回车>

创建一个启动脚本

:edit ~/.vimrc  编辑vimrc文件

:read $VIMRUNTIME/vimrc_example.vim  导入vimrc范例文件

:write   保存文件

一滴一点vim(学习+备忘)的更多相关文章

  1. vim操作命令备忘

    vim操作命令备忘 查找/替换 :%s/keyword//gn //搜索匹配的关键词数量 :%s/keywords/target //替换关键词 待续……

  2. Android学习备忘笺01Activity

    01.设置视图 在Android Studio新建的项目中,通过 setContentView(R.layout.activity_main);方法将res/layout/activity_main. ...

  3. leaflet 学习备忘

    leaflet 开源js地图工具.非常好用. leaflet参考:http://leafletjs.com/ 特性: 完全开源,可以基于不同的第三方瓦片生成地图. 基于原始GPS,无需转换 可创建离线 ...

  4. UML学习备忘

    两大类UML图: 行为图(behavior diagrams)和结构图(structure diagrams)     行为图将引导系统分析员分析且理清"系统该做些什么"?系统分析 ...

  5. Git学习备忘

    本文参考廖雪峰写的精彩的git学习文档,大家可以直接去官网看原版,我这里只是便于自己记录梳理 原版地址:http://www.liaoxuefeng.com/wiki/0013739516305929 ...

  6. MVC4 学习备忘

    WebConfig文件里添加数据库链接字符: <add name="MovieDBContext(可以自己取字符串名字)" connectionString="Da ...

  7. Vim配置文件备忘

    "我的配置 """""""""其他"""""&qu ...

  8. Linux下Vim使用备忘

    1.Insert键,决定是Insert模式还是Replace模式. 2.Esc键,退出编辑模式(Insert Or Replace). 3.:wq (ZZ) 保存并退出Vim. http://caib ...

  9. Hibernate学习备忘

    1.关于Hibernate异常: org.hibernate.service.jndi.JndiException: Error parsing JNDI name   刚接触Hibernate,调试 ...

随机推荐

  1. Oracle中NULL值与索引

    NULL值是关系数据库系统布尔型(true,false,unknown)中比较特殊类型的一种值,通常称为UNKNOWN或空值,即是未知的,不确定的.由于NULL存在着无数的可能,因此NULL值也不等于 ...

  2. win 7 64位如何安装erdas 9.2

    最主要的就是crack包必须包含这三个文件:erdas.exe、license.dat和lmgrd.exe 将这三个文件都复制到C盘安装目录下bin中,其余安装同win 7 32位系统

  3. 关于谷歌Chrome浏览器的两个Bug?

    1.网络资源下载莫名其妙的网络错误(也不支持续传?有时打开文件是损坏的?) 2.超级链接莫名的成了html下载?

  4. html 页面 ajax 方法显示遮罩

    showLoading.css 样式: ;;list-style-type:none;} a,img{;} .overlay{;;;;;width:100%;height:100%;_padding: ...

  5. linux源码分析2

    linux源码分析 这里使用的linux版本是4.8,x86体系. 这篇是 http://home.ustc.edu.cn/~boj/courses/linux_kernel/1_boot.html  ...

  6. Linux find example

    find | xargs echo >> x1 find -exec echo {} \; >> x2 1.查找/var目录下属主为root并且属组为mail的所有文件:fin ...

  7. [转载]vs2012中使用Spring.NET报错:Spring.Context.Support.ContextRegistry 的类型初始值设定项引发异常

    学习使用Spring.NET中的时候,写了一个Demo,在运行时报了一个错误:Spring.Context.Support.ContextRegistry 的类型初始值设定项引发异常. 重新整理思绪, ...

  8. hdu 1176

    简单DP  类似于在一个矩形中求最长路径 /************************************************************************* > ...

  9. spoj 2

    筛选法找素数  数据范围很大  1 <= m <= n <= 1000000000  一开始不知道怎么做  查了一下 先筛选出40000内的素数 再依靠这些素数筛选题目要求的素数 # ...

  10. uva 125

    floyd 算法   如果存在无数条路  则存在a->a的路  a->b的路径数等于 a->i 和 i->b(0=<i<=_max) 路径数的乘积和 #includ ...