常用指令收集
基础命令
" ctrl+q 可以联合复制,粘贴,替换用 行操作
" ctrl+w+j ctrl+w+k (:bn :bp :bd)
" ‘. 它移动光标到上一次的修改行
" 它移动光标到上一次的修改点
" . 重复上次命令
" : 依次沿着你的跳转记录向回跳 (从最近的一次开始)
" : 依次沿着你的跳转记录向前跳
" 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
(Y) 表示拷贝从当前光标到光标所在行尾的内容. " d
(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 重复插入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/KaTeX parse error: Undefined control sequence: \/ at position 96: … 替换为 bb " :s/\̲/̲bb/g …/d 空行(空格也不包含)删除.
" :%s/\r//g 删除DOS方式的回车^M
" :%s/ *
/
/
删
除
行
尾
空
白
(
// 删除行尾空白(%s/\s*
//删除行尾空白(//g)
" :g!/^dd/d 删除不含字符串’dd’开头的行
" :v/^dd/d 同上,译释:v == g!,就是不匹配!
" :v/./.,/./-1join 压缩空行(多行空行合并为一行)
" :g/^
/
,
/
.
/
−
j
压
缩
空
行
(
多
行
空
行
合
并
为
一
行
)
"
:
g
/
/
p
u
把
文
中
空
行
扩
增
一
倍
(
p
u
=
p
u
t
)
,
原
来
两
行
间
有
一
个
空
行
,
现
在
变
成
2
个
"
:
g
/
/
m
0
按
行
翻
转
文
章
(
m
=
m
o
v
e
)
"
:
g
/
f
r
e
d
/
,
/
j
o
e
/
d
n
o
t
l
i
n
e
b
a
s
e
d
(
v
e
r
y
p
o
w
e
r
f
u
l
l
)
"
:
g
/
<
i
n
p
u
t
∥
<
f
o
r
m
/
p
或
者
要
用
∥
"
:
g
/
f
r
e
d
/
t
/,/./-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
/,/./−j压缩空行(多行空行合并为一行)":g//pu把文中空行扩增一倍(pu=put),原来两行间有一个空行,现在变成2个":g//m0按行翻转文章(m=move)":g/fred/,/joe/dnotlinebased(verypowerfull)":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/ 标准正则表达式
" /1+/ 找一个以A~J中一个字母重复两次或以上开头的行
" /forum(_.)pent 多行匹配
" /fred_sjoe/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//z#.5 显示内容,还有行号
" :g//z#.5|echo ‘==========’ 漂亮的显示
多文档操作 (基础)
" 用 :ls! 可以显示出当前所有的buffer
" :bn 跳转到下一个buffer
" :bp 跳转到上一个buffer
" :wn 存盘当前文件并跳转到下一个
" :wp 存盘当前文件并跳转到上一个
" :bd 把这个文件从buffer列表中做掉
" :b 3 跳到第3个buffer
" :b main 跳到一个名字中包含main的buffer
列复制
" 译注:@#%&#*%#
!
"
:
! " :%s= [^ ]\+
!":=&&= : 复制最后一列
" :%s= \f+KaTeX parse error: Expected 'EOF', got '&' at position 2: =&̲&= : 一样的功能 " …=&& : ft,还是一样
" 反向引用,或称记忆
" 😒/(.)😦.)/\2 : \1/ : 颠倒用:分割的两个字段
" :%s/^(.*)\n\1/\1KaTeX parse error: Expected 'EOF', got '}' at position 24: …行 " 非贪婪匹配,\{-}̲ " :%s/^.\{-}…/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析取出路径
A-J ↩︎