请详细总结vim编辑器的使用并完成以下练习题
vi: Visual Interface,文本编辑器
文本:ASCII, Unicode
VIM – Vi IMproved
vim:模式化的编辑
基本模式:编辑模式(又叫命令模式)、输入模式(又叫插入模式)、末行模式:
模式转换:
编辑模式 –> 输入模式
i: insert, 在光标所在处输入;
a: append, 在光标所在处后面输入;
o: 在当前光标所在行的下方打开一个新行;
I:在当前光标所在行的行首输入;
A:在当前光标所在行的行尾输入;
O:在当前光标所在行的上方打开一个新行;
输入模式 –> 编辑模式
ESC
编辑模式 –> 末行模式
:
末行模式 –> 编辑模式
ESC
打开文件:
# vim [OPTION]… FILE…
+#: 打开文件后,直接让光标处于第#行的行首;
+/PATTERN:打开文件后,直接让光标处于第一个被PATTERN匹配到的行的行首;
关闭文件:
:q 退出
:q! 强制退出,丢弃做出的修改;
:wq 保存退出
:x 保存退出
:w /PATH/TO/SOMEWHERE
ZZ: 保存退出;
末行模式:内置的命令行接口
光标跳转:
字符间跳转:
h, j, k, l
h: 左
l: 右
j: 下
k: 上
#COMMAND:跳转由#指定的个数的字符;
单词间跳转:
w:下一个单词的词首
e:当前或下一单词的词尾
b:当前或前一个单词的词首
#COMMAND:由#指定一次跳转的单词数
行首行尾跳转:
^: 跳转至行首的第一个非空白字符;
0: 跳转至行首;
$: 跳转至行尾;
行间移动:
#G:跳转至由#指定行;
G:最后一行;
1G, gg: 第一行;
句间移动:
)
(
段落间移动:
}
{
vim的编辑命令:
字符编辑:
x: 删除光标处的字符;
#x: 删除光标处起始的#个字符;
xp: 交换光标所在处的字符及其后面字符的位置;
替换命令(r, replace)
r: 替换光标所在处的字符
删除命令:
d: 删除命令,可结合光标跳转字符,实现范围删除;
d$:
d^:
d0:
dw
de
db
#COMMAND
dd: 删除光标所在的行;
#dd:多行删除;
粘贴命令(p, put, paste):
p:缓冲区存的如果为整行,则粘贴当前光标所在行的下方;否则,则粘贴至当前光标所在处的后面;
P:缓冲区存的如果为整行,则粘贴当前光标所在行的上方;否则,则粘贴至当前光标所在处的前面;
复制命令(y, yank):
y: 复制,工作行为相似于d命令;
y$
y0
y^
ye
yw
yb
#COMMAND
yy:复制行
#yy: 复制多行;
改变命令(c, change)
c: 修改
编辑模式 –> 输入模式
c$
c^
c0
cb
ce
cw
#COMMAND
cc:删除并输入新内容
#cc:
其它编辑操作
可视化模式:
v: 按字符选定
V:按行行定
Note:经常结合编辑命令;
d, c, y
撤消此前的编辑:
u(undo):撤消此前的操作;
#u: 撤消指定次数的操作;
撤消此前的撤消:
Ctrl+r
重复前一个编辑操作:
.
翻屏操作:
Ctrl+f: 向文件尾部翻一屏;
Ctrl+b: 向文件首部翻一屏;
Ctrl+d: 向文件尾部翻半屏;
Ctrl+u:向文件首部翻半屏;
vim自带的练习教程:
vimtutor
末行模式编辑:
(1) 地址定界
:start_pos,end_pos
#: 具体第#行,例如2表示第2行;
#,#: 从左侧#表示行起始,到右侧#表示行结尾;
#,+#: 从左侧#表示的行起始,加上右侧#表示的行数;
.: 当前行
$: 最后一行
.,$-1
%:全文, 相当于1,$
/pat1/,/pat2/:
从第一次被pat1模式匹配到的行开始,一直到第一次被pat2匹配到的行结束;
#,/pat/
/pat/,$
使用方式:
后跟一个编辑命令
d
y
w /PATH/TO/SOMEWHERE: 将范围内的行另存至指定文件中;
r /PATH/FROM/SOMEFILE:在指定位置插入指定文件中的所有内容;
(2) 查找
/PATTERN:从当前光标所在处向文件尾部查找;
?PATTERN:从当前光标所在处向文件首部查找;
n:与命令同方向;
N:与命令反方向;
(3) 查找并替换
s: 在末行模式下完成查找替换操作
s/要查找的内容/替换为的内容/修饰符
要查找的内容:可使用模式
替换为的内容:不能使用模式,但可以使用\1, \2, …等后向引用符号;还可以使用“&”引用前面查找时查找到的整个内容;
修饰符:
i: 忽略大小写
g: 全局替换;默认情况下,每一行只替换第一次出现;
查找替换中的分隔符/可替换为其它字符,例如
s@@@
s###
1、复制/etc/rc.d/rc.sysinit文件至/tmp目录,将/tmp/rc.sysinit文件中的以至少一个空白字符开头的行的行首加#;
cp -a /etc/rc.d/rc.sysinit /tmp vim /tmp/rc.sysinit 输入: :%s/^[[:space:]]\+/#&/
2、复制/boot/grub/grub.conf至/tmp目录中,删除/tmp/grub.conf文件中的行首的空白字符;
cp -a /boot/grub/grub.conf /tmp vim /tmp/grub.conf 输入: :%s/^[[:space:]]\+//
3、删除/tmp/rc.sysinit文件中的以#开头,且后面跟了至少一个空白字符的行行的#和空白字符
vim /tmp/rc.sysinit 输入: :%s/^#[[:space:]]\+//
4、为/tmp/grub.conf文件中前三行的行首加#号;
vim /tmp/grub.conf 输入: :1,3s/^.*/#&/
5、将/etc/yum.repos.d/CentOS-Media.repo文件中所有的enabled=0或gpgcheck=0的最后的0修改为1;
vim /etc/yum.repos.d/CentOS-Media.repo 输入: :%s/enable=0/enable=1/g :%s/gpgcheck=0/gpgcheck=1/g
6、每4小时执行一次对/etc目录的备份,备份至/backup目录中,保存的目录名为形如etc-201504020202
crontab -e 输入: i #进入输入模式 0 */4 * * * cp -a /etc /backup/etc-$(date +%Y%m%d%H%M%S) :wq
7、每周2,4,6备份/var/log/messages文件至/backup/messages_logs/目录中,保存的文件名形如messages-20150402
crontab -e 输入: i #进入输入模式 * * * * 2,4,6 cp -a /var/log/messages /backup/messages_logs/messages-$(%Y%m%d) :wq
8、每天每两小时取当前系统/proc/meminfo文件中的所有以S开头的信息至/stats/memory.txt文件中
crontab -e 输入: i #进入输入模式 0 */2 * * * grep "^S.*"/proc/meminfo >> /stats/memory.txt :wq
9、工作日的工作时间内,每两小时执行一次echo "howdy"
* 9-17/2 * * 1-5 echo "howdy"
脚本编程练习
10、创建目录/tmp/testdir-当前日期时间;
mkdir -p /tmp/testdir-$(date +%Y-%m-%d-%H-%M-%S)
11、在此目录创建100个空文件:file1-file100
#!/bin/bash # cd /tmp/testdir-* for i in [1..100];do touch file$i done
12、显示/etc/passwd文件中位于第偶数行的用户的用户名;
sed -n 'n;p' /etc/passwd |cut -d: -f1
13、创建10用户user10-user19;密码同用户名;
#!/bin/bash # for i in [10..19];do useradd user$i echo "user$i" |passwd --stdin user$i done
14、在/tmp/创建10个空文件file10-file19;
#!/bin/bash # for i in [10..19];do mkdir -p /tmp/file$i done
15、把file10的属主和属组改为user10,依次类推。
#!/bin/bash # for i in [10..19];do chown user$i:user$i /tmp/file$i done
原创文章,作者:N20-重庆-雪寒,如若转载,请注明出处:http://www.178linux.com/18700
评论列表(1条)
写的很好,排版还可以在漂亮一点,加油