请详细总结vim编辑器的使用并完成以下练习题
vim(visual interface):文本编辑器
模式
编辑模式
输入模式
末行模式
模式之间的转换
编辑模式->输入模式
i
编辑模式->末行模式
:
输入模式->末行模式
不能直接转换,必须先到编辑模式在进入末行模式
输入模式->编辑模式
ESC
末行模式->编辑模式
ESC
末行模式->输入模式
不能直接切换,必须先转换到编辑模式在进入输入模式
编辑模式
1、复制/etc/rc.d/rc.sysinit文件至/tmp目录,将/tmp/rc.sysinit文件中的以至少一个空白字符开头的行的行首加#;
[root@localhost ~]# cp /etc/rc.d/rc.sysinit /tmp [root@localhost ~]# 1,$s/^\([[:space:]]\{1,\}\)/#\1/g
2、复制/boot/grub/grub.conf至/tmp目录中,删除/tmp/grub.conf文件中的行首的空白字符;
[root@localhost ~]# cp /boot/grub/grub.conf /tmp [root@localhost ~]# vim /tmp/grub.conf :1,$s/^[[:space:]]\{1,\}//g
3、删除/tmp/rc.sysinit文件中的以#开头,且后面跟了至少一个空白字符的行行的#和空白字符
[root@localhost ~]# vim /tmp/rc.sysinit :1,$s/^#[[:space:]]\+//g
4、为/tmp/grub.conf文件中前三行的行首加#号;
[root@localhost ~]# vim /tmp/grub.conf :1,3s/\(.*\)/#\1/g
5、将/etc/yum.repos.d/CentOS-Media.repo文件中所有的enabled=0或gpgcheck=0的最后的0修改为1;
vim /etc/yum.repos.d/CentOS-Media.repo 在末行模式中 :s/enabled=0/enabled=1/g :s/gpgcheck=0/gpgcheck=1/g
6、每4小时执行一次对/etc目录的备份,备份至/backup目录中,保存的目录名为形如etc-201504020202
root@localhost ~]# crontab -e root@localhost ~]# /mkdir backup * */4 * * * cp -a /etc /backup/etc-`date +%Y%m%d%H%M`
7、每周2,4,6备份/var/log/messages文件至/backup/messages_logs/目录中,保存的文件名形如messages-20150402
root@localhost ~]# crontab -e root@localhost ~]# mkdir /backup/messages_logs * * * * 2,4,6 /bin/cp -a /var/log/messages /backup/messages_logs/messages-`date +%Y%m%d`
8、每天每两小时取当前系统/proc/meminfo文件中的所有以S开头的信息至/stats/memory.txt文件中
root@localhost ~]# crontab -e root@localhost ~]# mkdir /stats */2 * * * /bin/egrep '^s|S' /proc/meminfo >> /stats/memory.txt
9、工作日的工作时间内,每两小时执行一次echo "howdy"
脚本编程练习
root@localhost ~]# crontab -e root@localhost ~]# mkdir /stats * */2 * * 1-5 /bin/echo "howdy"
脚本练习
10、创建目录/tmp/testdir-当前日期时间;
#!/bin/bash mkdir /tmp/testdir-`date +%Y%m%d%H`
11、在此目录创建100个空文件:file1-file100
#!/bin/bash for i in {1..100};do touch /tmp/testdir-2016082709/file$i done
12、显示/etc/passwd文件中位于第偶数行的用户的用户名;
#!/bin/bash a=`wc -l /etc/passwd | cut -d " " -f1` for i in $( seq 1 $a );do let v=$i%2 if [ $v == 0 ] then echo `head -n $i /etc/passwd | tail -n 1 | cut -d ":" -f1` fi done [root@localhost tmp]# bash test2 bin adm sync halt uucp games ftp dbus vcsa avahi-autoipd pulse saslauth ntp gdm tcpdump gentoo slackware hadoop testbsh nologin fedora
13、创建10用户user10-user19;密码同用户名;
#!/bin/bash for i in {10..19};do useradd user$i echo "user$i" | passwd -stdin done ~
14、在/tmp/创建10个空文件file10-file19;
#!/bin/bash for i in {10..19};do touch /tmp/testdir-2016082709/file$i done
15、把file10的属主和属组改为user10,依次类推。
#!/bin/bash for i in {10..19};do chown user$i:user$i file$i done
原创文章,作者:liliangming,如若转载,请注明出处:http://www.178linux.com/31172
评论列表(1条)
完成的非常的好,5题还有一种方法可以实现的: %s@\(gpgcheck\|enabled\)=0@\1=1@