###《VIM实用技巧》

#@author:       gr
#@date: 2015-11-20
#@email: forgerui@gmail.com

《VIM实用技巧》阅读笔记。

1. 使用>, <进行缩进

>G    #从当前行缩进到最后一行
v > #利用v选中需要缩进的行,然后缩进

2. f行内快速定位

要在一行内快速移动到某个字符,使用f。

f+    #定位到本行中的+

使用;定位下一个,,定位上一个。

3. s

s命令可以删除当前字符,并切换到编辑模式。

S命令可以删除当前行,并切换到编辑模式。

C = c$,删除当前行所在字符以后的所有字符。

4. aw

dwcw都只能删除当前字符到单词最后,使用dawdcw可以删除整个字符,并且会把前面的空格也删除。

5. global

  1. :g/{pattern}/ [cmd]

     :g/^\s*$/ d    #删除空格行
  2. :g/{pattern}/ [range] [cmd]

     :g/{/ .+1, /}/-1 sort    #对大括号里内容进行排序

6. 自动补全

<C-n> 上一条

<C-p> 下一条

7. 可视区

gv选中上一次的选中可视区。'<, '>也表示上一次选中区。

:'<, '> d

8. 大小写转换

gU变大写

gu变小写

g~大小写互换

9. 寄存器

":默认寄存器

0:复制专用寄存器

+:系统寄存器

与系统进行复制。

"+y    //复制内容到系统寄存器
"+p //粘贴系统寄存器内容

其它寄存器:

"%:当前文件名

"/:上次查找的模式

10. set paste

当用系统寄存器粘贴时,由于autoindent会导致许多缩进,这时使用set paste选项就可避免,粘贴完使用set nopaste关闭即可。

11. 跳转

'a:单引号跳转到行

``a`:跳转到具体单词

<C-o>:返回到上一条位置

12. 行间移动

w:下一个单词开头

b:上一个单词开头

e :下一个单词结尾

ge:上一个单词结尾

f:查找下一个字符

t:查找上一个字符

13. 文件状态

<C-g>查看当前文件状态。

14. 用root用户保存

:w !sudo tee %

15. 文件系统

:e ../ #打开上层目录
:E #打开当前目录
- #返回上层目录

16. 自动补全

<C-d>:自动补全,忘记命令时可以使用自动补全查看候选项

set exp<C-d>

17. :t:m

copy简写为tmove简写为md删除。

:[range] copy {address}
:6copy. # 把第6行复制到当前行
:10,$ m . # 把第10行到最后一行内容移动到当前行

18. 执行上次Ex命令

@:执行上次Ex命令

19. 插入模式执行命令

在插入模式中,如果不想退出,当前行显示在屏幕中央,可以<C-o> zz

插入模式中,用<C-r>寄存器输入寄存器的内容。用<C-r>=做运算。

###《VIM实用技巧》的更多相关文章

  1. 简单物联网:外网访问内网路由器下树莓派Flask服务器

    最近做一个小东西,大概过程就是想在教室,宿舍控制实验室的一些设备. 已经在树莓上搭了一个轻量的flask服务器,在实验室的路由器下,任何设备都是可以访问的:但是有一些限制条件,比如我想在宿舍控制我种花 ...

  2. 利用ssh反向代理以及autossh实现从外网连接内网服务器

    前言 最近遇到这样一个问题,我在实验室架设了一台服务器,给师弟或者小伙伴练习Linux用,然后平时在实验室这边直接连接是没有问题的,都是内网嘛.但是回到宿舍问题出来了,使用校园网的童鞋还是能连接上,使 ...

  3. 外网访问内网Docker容器

    外网访问内网Docker容器 本地安装了Docker容器,只能在局域网内访问,怎样从外网也能访问本地Docker容器? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装并启动Docker容器 ...

  4. 外网访问内网SpringBoot

    外网访问内网SpringBoot 本地安装了SpringBoot,只能在局域网内访问,怎样从外网也能访问本地SpringBoot? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装Java 1 ...

  5. 外网访问内网Elasticsearch WEB

    外网访问内网Elasticsearch WEB 本地安装了Elasticsearch,只能在局域网内访问其WEB,怎样从外网也能访问本地Elasticsearch? 本文将介绍具体的实现步骤. 1. ...

  6. 怎样从外网访问内网Rails

    外网访问内网Rails 本地安装了Rails,只能在局域网内访问,怎样从外网也能访问本地Rails? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装并启动Rails 默认安装的Rails端口 ...

  7. 怎样从外网访问内网Memcached数据库

    外网访问内网Memcached数据库 本地安装了Memcached数据库,只能在局域网内访问,怎样从外网也能访问本地Memcached数据库? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装 ...

  8. 怎样从外网访问内网CouchDB数据库

    外网访问内网CouchDB数据库 本地安装了CouchDB数据库,只能在局域网内访问,怎样从外网也能访问本地CouchDB数据库? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装并启动Cou ...

  9. 怎样从外网访问内网DB2数据库

    外网访问内网DB2数据库 本地安装了DB2数据库,只能在局域网内访问,怎样从外网也能访问本地DB2数据库? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装并启动DB2数据库 默认安装的DB2 ...

  10. 怎样从外网访问内网OpenLDAP数据库

    外网访问内网OpenLDAP数据库 本地安装了OpenLDAP数据库,只能在局域网内访问,怎样从外网也能访问本地OpenLDAP数据库? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装并启动 ...

随机推荐

  1. 蓝桥杯--Quadratic Equation

    蓝桥杯--Quadratic Equation 问题描述 求解方程ax2+bx+c=0的根.要求a, b, c由用户输入,并且可以为任意实数. 输入格式:输入只有一行,包括三个系数,之间用空格格开. ...

  2. nodejs小问题:[1]express不是内部或外部命令

    nodejs小问题:[1]express不是内部或外部命令 浏览:9424 | 更新:2015-08-28 05:31 1 2 3 4 5 6 7 分步阅读 一时兴起想学习点东西,准备在heroku上 ...

  3. Chrome插件开发 尝试1

    1.新建文件夹 如图:整个项目的结构 2.新建一个名为manifest.json的文件,编码模式为utf-8,(可以先建好txt文件然后再将文件后缀txt改为json) 3.用记事本写入代码如下:(m ...

  4. iOS开发——网络Swift篇&NSURL进行数据请求(POST与GET)

    NSURL进行数据请求(POST与GET)   使用Swift进行iOS开发时,不可避免的要进行远程的数据获取和提交. 其数据请求的方式既可能是POST也可能是GET.同不管是POST还是GET又可以 ...

  5. cuda-convnet 卷积神经网络 一般性结构卷积核个数 和 输入输出的关系以及输入输出的个数的说明:

    卷积神经网络 一般性结构卷积核个数和 输入输出的关系以及输入输出的个数的说明: 以cifar-10为例: Initialized data layer 'data', producing3072 ou ...

  6. C++标准转换运算符const_cast

    前面讲了C++继承并扩展C语言的传统类型转换方式,最后留下了一些关于指针和引用上的转换问题,没有做详细地讲述.C++相比于C是一门面向对象的语言,面向对象最大的特点之一就是具有“多态性(Polymor ...

  7. HelloSpark.scala

    /** * Created by root on 9/6/15. */ import org.apache.spark.SparkContext import org.apache.spark.Spa ...

  8. SQL Server日期函数总结

    获得一个月的天数:首先到得一个月最后一天的日期,通过 SQL Server 日期函数 day() 取得日期中的“天 ”部分 获得 2008 年 2 月份的天数:select day(cast('200 ...

  9. debian创建apt-proxy代理

    由于公司网络比较慢.所以需要建立一个代理服务器或镜象站点!考虑到创建和维护镜象的投入比较大!所以选择apt-proxy代理来做!可以缓解公司带宽不足的矛盾.而且只有在代理缓存,没有相应组件的情况下才去 ...

  10. MYSQL查询今天昨天本周本月等的数据

    mysql查询本季度 今天 select * from 表名 where to_days(时间字段名) = to_days(now()); 昨天 SELECT *FROM表名WHERE TO_DAYS ...