N25-第6周

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

(0)
VersionVersion
上一篇 2017-02-13
下一篇 2017-02-13

相关推荐

  • Corosync + Pacemaker 搭建高可用MariaDB服务

    Corosync + Pacemaker 搭建高可用MariaDB服务 实验描述 1.本实验的目的是为了通过手动配置corosync配置文件,实现MariaDB服务的高可用,集群心跳传递使用组播方式。2.三个节点的主机名分别为:node5.redhat.com、node6.redhat.com、node7.redhat.com。地址为172.16.100.5…

    Linux干货 2016-04-06
  • Linux命令中特殊符号的用法

    Linux命令中特殊符号的用法 在马哥教育学习了将近一周的Linux运维,由最初对Linux系统的一无所知,到了解了Linux的发展历程,学习了一些基本命令,惊叹于Linux的强大功能。下面根据我学到的,介绍一下关于Linux命令中特殊符号的用法。 $的用法 1.$()或’’引用命令执行的结果 例如:如果我们想要创建一个以当前日期命名的目录,可以执行 #mk…

    2017-07-15
  • vim文本编辑器使用

    vim文本编辑器使用

    2017-09-20
  • Linux程序包管理(二)YUM使用

    YUM Linux程序包管理(二) 说完了程序包管理以及rpm的相关使用,接下来说说rpm的前端管理工具 YUM YUM是什么? &emsp;&emsp;&emsp;前面提到,yum是rpm程序包管理器的前端管理工具,那么yum到底是什么?又能做什么呢? YUM:yellow dog,Yellowdog Update Mod…

    Linux干货 2016-06-01
  • Linux基础之权限管理(含SUID\SGID\STICKY和ACL)

    概述     Linux系统是一个多人多任务的操作系统,系统上同时可能有很多人登录,每个人都会利用系统上的各类资源完成一定的操作。那么如何合理的规范这些用户的行为,保证资源的合理分配,则就需要用到权限管理的相关内容了。权限管理是Linux系统上最基础,也是最重要的一部分内容,本章就简要说明下权限管理的相关内容。内容主要…

    Linux干货 2016-08-04
  • PXE

    BootStraping 系统提供 PXE 简介 PXE(preboot execute environment,预启动执行环境)是由Intel公司开发的最新技术,工作于Client/Server的网络模式,支持工作站通过网络从远端服务器下载映像,并由此支持通过网络启动操作系统,在启动过程中,终端要求服务器分配IP地址,再用TFTP(trivial file…

    Linux干货 2016-11-05

评论列表(1条)

  • 马哥教育
    马哥教育 2017-03-30 14:13

    格式有点花,但内容还是没有问题的,再接再励。