vim:
模式化的编辑器
基本模式:
编辑模式,命令模式,
输入模式
末行模式:
内置的命令行借口;
打开文件:
编辑模式:默认模式
编辑模式–>输入模式:
i:insert,在光标所在处输入;
a:append,在光标所在处后方输入;
o:在光标所在处的下方打开一个新行;
I:子啊光标所在行的行首输入;
A:在光标所在行的行尾输入;
O:在光标所在处的上方打开一个新行;
输入模式–>编辑模式
ESC
编辑模式–>末行模式
:
末行模式–>编辑模式
ESC
关闭文件:
ZZ:保存并提出;
:q 退出
:q! 强制退出,不保存此前的编辑操作
:wq 保存并退出;
:w /PATH/TO/SOMEFILE 另存为
光标跳转:
字符间跳转
h:左
j:下
k:上
l:右
#COMMAND:跳转由#指定的个数的字符;
单词间跳转
w:下一个单词的词首;
e:当前或后一个单词的词尾;
b:当前或前一个单词的词首;
#COMMAND:跳转由#指定的个数的单词;
行首行尾跳转
^:跳转至行首的第一个非空白字符;
0:跳转至行首;
$:跳转至行尾;
行间跳转
#G:跳转至#指定的行;
1G,gg:第一行;
G:最后一行;
句间跳转
) 下一句
( 上一句
#):跳转后#句
#(:跳转前#句
段间跳转
} 上一段
{ 下一段
#}:跳转后#段
#{:跳转前#段
翻屏:
Ctrl+f:向文件尾部翻一屏
Ctrl+b:向文件首部翻一屏
Ctrl+d:向文件尾部翻半屏
Ctrl+u:向文件首部翻半屏
Enter:按行向后翻
vim的编辑命令:
字符编辑
x:删除光标所在处的字符;
#x:删除光标所在处起始的#个字符;
xp:交换光标所在处的字符与其后面的字符的位置;
替换命令(replace):
r:替换光标所在处的字符;
rCHAR
删除命令:
d:删除命令,可结合光标跳转字符,实现范围删除;
d$:
d^:
dw:
de:
db:
#COMMAND:
dd:删除光标所在处的行;
#dd:删除光标所处的行起始的共#行;
粘贴命令(p,put。paste):
p:缓冲区的内容如果为整行,则粘贴在当前光标所在行的下方;否则粘贴至当前光标所在处的后方;
P:缓冲区的内容如果为整行,则粘贴在当前光标所在行的上方;否则粘贴至当前光标所在处的前方;
复制命令(yank,y):
y:复制,工作行为相似于d命令
y$
y^
y0
ye
yw
yb
#COMMAND
yy:复制一整行
#yy:复制#行
改变命令(change,c):修改
编辑模式–>输入模式 ,实现删除操作;
c$
c^
c0
cb
ce
cw
#COMMAND
cc:删除光标所在的行,并转换为输入模式;
#cc:
其他的编辑操作:
可视化模式:选定(向鼠标一样选定)
v:按字符选定;
V:按行选定;
结合编辑命令:d,c,y
撤销(undo)操作:
u:撤销此前的操作;
#u:撤销此前的#个操作;
撤销此前的撤销:
Ctrl+r
重复执行前一个编辑操作;
.
vim自带的练习教程:vimtutor
vim末行模式: 内建命令行接口
1.地址界定
:start_pos[,end_pos]
#:特定的第#行,例如5即di5行;
.:当前行;
$:最后一行;
#,#:指定行范围,左侧为起始行,右侧为结束行;
#,+#:指定范围,左侧为起始绝对编号,右侧为相对左侧行号的偏移量;例如:3,+7
.,$-1
1,$
%:全文
/pattern/:从光标所在处起始向文件尾部第一次被模式所匹配到的行;
/first/,$
/pat1/,/pat2/:从光标所在处起始,第一次由pat1匹配到的行开始,至第一次由pat2匹配到的行结束之间的所有行;
可同编辑命令一同使用,实现编辑操作:
d
y
c
w /PATH/TO/SOMEFILE:将范围内的文本保存至指定的文件中;
r /PATH/FROM/SOMEFILE:将指定的文件中的文本读取并插入至指定位置;
2.查找
/PATTERN:从当前光标所在处向文件尾部查找能够被当前模式匹配到的所有字符串;
?/PATTERN:从当前光标所在处向文件首部查找能够被当前模式匹配到的所有字符串;
n:下一个,与命令方向相同;
N:上一个,与命令方向相反;
3.查找并替换
s:末行模式的命令;使用格式:
s/要查找的内容/替换为的内容/修饰符
要查找的内容:可使用正则表达式;
替换为的内容:不能使用正则表达式,但可以引用;
如果“要查找的内容”部分在模式中使用分组符号:在“替换为的内容”中使用后向引用;
直接引用查找模式匹配到的全部文本;
修饰符:
i:忽略大小写;
g:全局替换,意味着一行中如果匹配到多次,则均替换;
可把分隔符替换为其他非常用字符:
s@@@
s###
1、复制/etc/rc.d/rc.sysinit文件至/tmp目录,将/tmp/rc.sysinit文件中的以至少一个空白字符开头的行的行首加#;
1
:%s/^[[:space:]]\{1,\}.*/#&/g
2、复制/boot/grub/grub.conf至/tmp目录中,删除/tmp/grub.conf文件中的行首的空白字符;
1
:%s/^[[:space:]]\{1,\}//g
3、删除/tmp/rc.sysinit文件中的以#开头,且后面跟了至少一个空白字符的行行的#和空白字符
1
:%s/^#[[:space:]]\{1,\}//g
4、为/tmp/grub.conf文件中前三行的行首加#号;
1
:1,3s/^/#&/
5、将/etc/yum.repos.d/CentOS-Media.repo文件中所有的enabled=0或gpgcheck=0的最后的0修改为1;
1
:%s@\(enabled\|gpgcheck\)=0@\1=1@g
6、每4小时执行一次对/etc目录的备份,备份至/backup目录中,保存的目录名为形如etc-201504020202
1
0 */4 * * * /usr/bin/cp -r /etc/ /backup/etc-`date +%Y%m%d%H%M%S`/ >dev/null 2>&1
7、每周2,4,6备份/var/log/messages文件至/backup/messages_logs/目录中,保存的文件名形如messages-20150402
1
0 0 * * 2,4,6 /usr/bin/cp -r /var/log/messages /backup/messages_logs/messages-`date +%Y%m%d` >/dev/null 2>&1
8、每天每两小时取当前系统/proc/meminfo文件中的所有以S开头的信息至/stats/memory.txt文件中
1
0 */2 * * * /usr/bin/grep '^S' /proc/meminfo >> /stats/memory.txt >/dev/null 2>&1
9、工作日的工作时间内,每两小时执行一次echo "howdy"
1
0 9-18/2 * * echo "howdy" 2>&1
脚本编程练习
10、创建目录/tmp/testdir-当前日期时间;
1
2
3
4
5
6
7
8
9
10
11
12
13
14
#!/bin/bash
#
DATE=`date +%Y%m%d%H%M%S`
if [ -d /tmp/testdir-$DATE ];then
echo "testdir-$DATE is exist!"
exit 2
else
mkdir /tmp/testdir-$DATE
if [ -d /tmp/testdir-$DATE ];then
echo "create testdir-$DATE success!"
else
echo "create failure testdir-$DATE!"
fi
fi
11、在此目录创建100个空文件:file1-file100
1
2
3
4
5
6
7
8
9
#!/bin/bash
#
for i in {1..100};do
if [ -e /tmp/file$i ];then
echo "/tmp/file$i exist"
else
touch /tmp/file$i
fi
done
12、显示/etc/passwd文件中位于第偶数行的用户的用户名;
1
2
3
4
5
6
7
8
#!/bin/bash
#
FILE=/etc/passwd
SUM=`wc -l $FILE|cut -d' ' -f1`、
for i in $(seq 2 2 $SUM);do
NAME=`head -n$i $FILE|tail -1|cut -d: -f1`
echo "$NAME "
done
13、创建10用户user10-user19;密码同用户名;
1
2
3
4
5
6
7
8
9
10
11
#!/bin/bash
#
for i in {10..19};do
if id user$i &>/dev/null;then
echo "user$i exist,adduser failure"
else
useradd user$i
echo "user$i"|passwd –stdin user$i >/dev/null
echo "user$i add success"
fi
done
14、在/tmp/创建10个空文件file10-file19;
1
2
3
4
5
6
7
8
9
#!/bin/bash
#
for ((i=10;i<=19;i++));do
if [ -e /tmp/file$i ];then
echo "/tmp/file$i exist"
else
touch /tmp/file$i
fi
done
15、把file10的属主和属组改为user10,依次类推。
1
2
3
4
5
#!/bin/bash
#
for ((i=10;i<=19;i++));do
chown user$i:user$i /tmp/file$i
done
原创文章,作者:Version,如若转载,请注明出处:http://www.178linux.com/68318
评论列表(1条)
格式有点花,但内容还是没有问题的,再接再励。