JSRUN 用代码说话

vi/vim命令大全

编辑教程

vi/vim命令大全

"/*========================================*\

" 常用指令收集

"\*========================================*/

" 系统时间

" :map <F7> a<C-R>=strftime("%c")<CR><esc>

" :s/__date__/\=strftime("%c")/

"/*---------------------------------------*\

" 基础命令

"/*---------------------------------------*\

" ctrl+q 可以联合复制,粘贴,替换用 行操作

" ctrl+w+j ctrl+w+k (:bn :bp :bd)

" '. 它移动光标到上一次的修改行

" `. 它移动光标到上一次的修改点

" . 重复上次命令

" <C-O> : 依次沿着你的跳转记录向回跳 (从最近的一次开始)

" <C-I> : 依次沿着你的跳转记录向前跳

" ju(mps) : 列出你跳转的足迹

" :history : 列出历史命令记录

" :his c : 命令行命令历史

" :his s : 搜索命令历史

" q/ : 搜索命令历史的窗口

" q: : 命令行命令历史的窗口

" g ctrl+g 计算文件字符

" {,} 前进至上一段落前进至后一段落

" gg,G(2G) 文件首

" gd dw gf ga(进制转化)

" gg=G 全篇自动缩进 , =G 单行缩进

"* ci[ 删除一对 [] 中的所有字符并进入插入模式

"* ci( 删除一对 () 中的所有字符并进入插入模式

"* ci< 删除一对 <> 中的所有字符并进入插入模式

"* ci{ 删除一对 {} 中的所有字符并进入插入模式

"* cit 删除一对 HTML/XML 的标签内部的所有字符并进入插入模式

"* ci” ci’ ci` 删除一对引号字符 (” 或 ‘ 或 `) 中所有字符并进入插入模式

"

"* vi[ 选择一对 [] 中的所有字符

"* vi( 选择一对 () 中的所有字符

"* vi< 选择一对 <> 中的所有字符

"* vi{ 选择一对 {} 中的所有字符

"* vit 选择一对 HTML/XML 的标签内部的所有字符

"* vi” vi’ vi` 选择一对引号字符 (” 或 ‘ 或 `) 中所有字符

" crl+] 函数原型处 crl+t 回 ( ctags )

" ctl+p 自动补全( 编辑状态 )

" :X 加密保存( 要输入密码 )

" ? / (N n)

" f(F,t) 查找字符

" w(e) 移动光标到下一个单词.

" 5fx 表示查找光标后第 5 个 x 字符.

" 5w(e) 移动光标到下五个单词.

" b 移动光标到上一个单词.

" 0 移动光标到本行最开头.

" ^ 移动光标到本行最开头的字符处.

" $ 移动光标到本行结尾处.

" H 移动光标到屏幕的首行.

" M 移动光标到屏幕的中间一行.

" L 移动光标到屏幕的尾行.

" c-f (即 ctrl 键与 f 键一同按下)

" c-b (即 ctrl 键与 b 键一同按下) 翻页

" c-d (下半页) c-u(上半页) c-e (一行滚动)

" zz 让光标所在的行居屏幕中央

" zt 让光标所在的行居屏幕最上一行

" zb 让光标所在的行居屏幕最下一行

" 在 vi 中 y 表示拷贝, d 表示删除, p 表示粘贴. 其中拷贝与删除是与光标移动命令

" yw 表示拷贝从当前光标到光标所在单词结尾的内容.

" dw 表示删除从当前光标到光标所在单词结尾的内容.

" y0 表示拷贝从当前光标到光标所在行首的内容.

" d0 表示删除从当前光标到光标所在行首的内容.

" y$(Y) 表示拷贝从当前光标到光标所在行尾的内容.

" d$(D) 表示删除从当前光标到光标所在行尾的内容.

" yfa 表示拷贝从当前光标到光标后面的第一个a字符之间的内容.

" dfa 表示删除从当前光标到光标后面的第一个a字符之间的内容.

" s(S),a(A),x(X),D

" yy 表示拷贝光标所在行.

" dd 表示删除光标所在行.

" 5yy 表示拷贝光标以下 5 行.

" 5dd 表示删除光标以下 5 行.

" y2fa 表示拷贝从当前光标到光标后面的第二个a字符之间的内容.

" :12,24y 表示拷贝第12行到第24行之间的内容.

" :12,y 表示拷贝第12行到光标所在行之间的内容.

" :,24y 表示拷贝光标所在行到第24行之间的内容. 删除类似.

" TAB 就是制表符, 单独拿出来做一节是因为这个东西确实很有用.

" << 输入此命令则光标所在行向左移动一个 tab.

" >> 输入此命令则光标所在行向右移动一个 tab.

" 5>> 输入此命令则光标后 5 行向右移动一个 tab.

" :5>>(>>>) :>>(>>>)5

" :12,24> 此命令将12行到14行的数据都向右移动一个 tab.

" :12,24>> 此命令将12行到14行的数据都向右移动两个 tab.

" :set shiftwidth=4 设置自动缩进 4 个空格, 当然要设自动缩进先.

" :set sts=4 即设置 softtabstop 为 4. 输入 tab 后就跳了 4 格.

" :set tabstop=4 实际的 tab 即为 4 个空格, 而不是缺省的 8 个.

" :set expandtab 在输入 tab 后, vim 用恰当的空格来填充这个 tab.

" :g/^/exec 's/^/'.strpart(line('.').' ', 0, 4) 在行首插入行号

" set ai 设置自动缩进

" 5ia<esc> 重复插入5个a字符

"/*---------------------------------------*\

" 替换命令

"/*---------------------------------------*\

" 替换文字 2009-02-34 ----> 2009-02-34 00:00:00

" :%s/\(\d\{4\}-\d\{2\}-\d\{2\}\)/\1 00:00:00/g

" :%s/^/heaser/ 在每一行头部添加header

" :%s/$/ender/ 在每一行尾部添加ender

" :s/aa/bb/g 将光标所在行出现的所有包含 aa 的字符串中的 aa 替换为 bb

" :s/\/bb/g 将光标所在行出现的所有 aa 替换为 bb, 仅替换 aa 这个单词

" :%s/aa/bb/g 将文档中出现的所有包含 aa 的字符串中的 aa 替换为 bb

" :12,23s/aa/bb/g 将从12行到23行中出现的所有包含 aa 的字符串中的 aa 替换为 bb

" :12,23s/^/#/ 将从12行到23行的行首加入 # 字符

" :%s/fred/joe/igc 一个常见的替换命令,修饰符igc和perl中一样意思

" s/dick/joe/igc则 对于这些满足条件的行进行替换

" :g/^\s*$/d 空行(空格也不包含)删除.

" :%s/\r//g 删除DOS方式的回车^M

" :%s/ *$// 删除行尾空白(%s/\s*$//g)

" :g!/^dd/d 删除不含字符串'dd'开头的行

" :v/^dd/d 同上,译释:v == g!,就是不匹配!

" :v/./.,/./-1join 压缩空行(多行空行合并为一行)

" :g/^$/,/./-j 压缩空行(多行空行合并为一行)

" :g/^/pu _ 把文中空行扩增一倍 (pu = put),原来两行间有一个空行,现在变成2个

" :g/^/m0 按行翻转文章 (m = move)

" :g/fred/,/joe/d not line based (very powerfull)

" :g/<input\|<form/p 或者 要用\|

" :g/fred/t$ 拷贝行,从fred到文件末尾(EOF)

" :%norm jdd 隔行删除,译释:%指明是对所有行进行操作,norm指出后面是normal模式的指令,j是下移一行,dd是删除行

" :'a,'bg/fred/s/dick/joe/igc ('a,'b指定一个范围:mark a ~ mark b)

" g//用一个正则表达式指出了进行操作的行必须可以被fred匹配,g//是一个全局显示命令

" /joe/e 光标停留在匹配单词最后一个字母处

" /joe/e+1 光标停留在匹配单词最后一个字母的下一个字母处

" /joe/s 光标停留在匹配单词第一个字母处

" /^joe.*fred.*bill/ 标准正则表达式

" /^[A-J]\+/ 找一个以A~J中一个字母重复两次或以上开头的行

" /forum\(\_.\)*pent 多行匹配

" /fred\_s*joe/i 中间可以有任何空白,包括换行符\n

" /fred\|joe 匹配FRED或JOE

" /\<fred\>/i 匹配fred,fred必须是一个独立的单词,而不是子串

" /\<\d\d\d\d\> 匹配4个数字 \<\d\{4}\>

" 列,替换所有在第三列中的str1

" :%s:\(\(\w\+\s\+\)\{2}\)str1:\1str2:

" 交换第一列和最后一列 (共4列)

" :%s:\(\w\+\)\(.*\s\+\)\(\w\+\)$:\3\2\1:

" 全局(global)显示命令,就是用 :g+正则表达式

" 译释: :g/{pattern}/{cmd} 就是全局找到匹配的,然后对这些行执行命令{cmd}

" :g/\<fred\>/ 显示所有能够为单词fred所匹配的行

" :g/<pattern>/z#.5 显示内容,还有行号

" :g/<pattern>/z#.5|echo '==========' 漂亮的显示

"/*---------------------------------------*\

" 多文档操作 (基础)

"/*---------------------------------------*\

" 用 :ls! 可以显示出当前所有的buffer

" :bn 跳转到下一个buffer

" :bp 跳转到上一个buffer

" :wn 存盘当前文件并跳转到下一个

" :wp 存盘当前文件并跳转到上一个

" :bd 把这个文件从buffer列表中做掉

" :b 3 跳到第3个buffer

" :b main 跳到一个名字中包含main的buffer

"/*---------------------------------------*\

" 列复制

"/*---------------------------------------*\

" 译注:@#%&^#*^%#$!

" :%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/

" 译注:就是用 | 管道啦

"/*---------------------------------------*\

" 大小写转换

"/*---------------------------------------*\

" g~~ : 行翻转

" vEU : 字大写(广义字)

" vE~ : 字翻转(广义字)

" ~ 将光标下的字母改变大小写

" 3~ 将下3个字母改变其大小写

" g~w 字翻转

" U 将可视模式下的字母全改成大写字母

" gUU 将当前行的字母改成大写

" u 将可视模式下的字母全改成小写

" guu 将当前行的字母全改成小写

" gUw 将光标下的单词改成大写。

" guw 将光标下的单词改成小写。

" 文件浏览

" :Ex : 开启目录浏览器,注意首字母E是大写的

" :Sex : 在一个分割的窗口中开启目录浏览器

" :ls : 显示当前buffer的情况

" :cd .. : 进入父目录

" :pwd

" :args : 显示目前打开的文件

" :lcd %:p:h : 更改到当前文件所在的目录

" 译释:lcd是紧紧改变当前窗口的工作路径,% 是代表当前文件的文件名,

" 加上 :p扩展成全名(就是带了路径),加上 :h析取出路径

以下是一张vim常用命令速查表:685007-20190219103431877-1441653557

JSRUN闪电教程系统是国内最先开创的教程维护系统, 所有工程师都可以参与共同维护的闪电教程,让知识的积累变得统一完整、自成体系。 大家可以一起参与进共编,让零散的知识点帮助更多的人。
X
支付宝
9.99
无法付款,请点击这里
金额: 0
备注:
转账时请填写正确的金额和备注信息,到账由人工处理,可能需要较长时间
如有疑问请联系QQ:565830900
正在生成二维码, 此过程可能需要15秒钟