N25-第6周博客作业

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文件中的以至少一个空白字符开头的行的行首加#;

:%s/^[[:space:]]\{1,\}.*/#&/g

2、复制/boot/grub/grub.conf至/tmp目录中,删除/tmp/grub.conf文件中的行首的空白字符;

:%s/^[[:space:]]\{1,\}//g

3、删除/tmp/rc.sysinit文件中的以#开头,且后面跟了至少一个空白字符的行行的#和空白字符

:%s/^#[[:space:]]\{1,\}//g

4、为/tmp/grub.conf文件中前三行的行首加#号;

:1,3s/^/#&/

5、将/etc/yum.repos.d/CentOS-Media.repo文件中所有的enabled=0或gpgcheck=0的最后的0修改为1;

:%s@\(enabled\|gpgcheck\)=0@\1=1@g

6、每4小时执行一次对/etc目录的备份,备份至/backup目录中,保存的目录名为形如etc-201504020202

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

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文件中

0 */2 * * * /usr/bin/grep '^S' /proc/meminfo  >> /stats/memory.txt  >/dev/null  2>&1

9、工作日的工作时间内,每两小时执行一次echo "howdy"

0 9-18/2 * * echo "howdy" 2>&1

脚本编程练习

10、创建目录/tmp/testdir-当前日期时间; 

#!/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

#!/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文件中位于第偶数行的用户的用户名;

#!/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;密码同用户名;

#!/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; 

#!/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,依次类推。

#!/bin/bash
#
for ((i=10;i<=19;i++));do
chown user$i:user$i /tmp/file$i
done

原创文章,作者:oranix,如若转载,请注明出处:http://www.178linux.com/66193

(0)
oranixoranix
上一篇 2017-01-09
下一篇 2017-01-09

相关推荐

  • 第三周博客作业

      开始学习已经三周了,感觉到年底有些时间不够,作业也交的越来越晚,需要加紧学习的进度了。   1、列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次即可。  最简单的实现题目要求的方法是使用cut命令只显示用户名并用sort命令排序去重: [root@localhost ~]# who |&nbs…

    Linux干货 2016-12-20
  • Linux基础命令 -管道密切配合使用 tee

    基础命令和管道密切配合使用  tee     基础命令:tee   tee命令 功能: 把命令1的STDOUT保存在文件名中,然后管道输入给命令2; 补充说明:tee指令会从标准输入设备读取数据,将其内容输出到标准输出设备,同时保存成文件。 使用场景: 1.保存不同阶段的输出 2.复杂管道的故障排除 3.同时查看和记录…

    Linux干货 2016-08-03
  • Linux磁盘管理实操

    Linux磁盘管理实操 1、创建一个10G分区,并格式为ext4文件系统。 先使用fdisk工具创建一个10G的新分区。使用fdisk打开要创建磁盘分区的物理设备fdisk /dev/sdb,然后使用n指令创建新的分区,分区类型选此处选择为主分区,第一个柱面使用默认的1,最后的柱面,使用+10G这种表示方式,表示创建的分区大小为10G。 创建后可以使用p指令…

    系统运维 2016-12-13
  • Nginx4大模块——proxy、headers、upstream、stream模块

    Nginx 应用程序发布: 灰度模型:          (1) 如果存在用户会话;              从服务器上拆除会话;   &…

    Linux干货 2016-10-29
  • 谷歌三大核心技术(一)The Google File System中文版

    摘要 我们设计并实现了Google GFS文件系统,一个面向大规模数据密集型应用的、可伸缩的分布式文件系统。GFS虽然运行在廉价的普遍硬件设备上,但是它依然了提供灾难冗余的能力,为大量客户机提供了高性能的服务。 虽然GFS的设计目标与许多传统的分布式文件系统有很多相同之处,但是,我们的设计还是以我们对自己的应用的负载情况和技术环境的分析为基础的,不管现在还是…

    Linux干货 2015-04-13
  • 三次握手,四次挥手

    TCP/IP协议的详细信息参看《TCP/IP协议详解》三卷本。 在谈及TCP建立连接和释放连接过程,先来简单认识一下TCP报文段首部格式的的几个名词(这里只是简单说明,具体请查看相关教程)下面是TCP报文格式图:     序列号seq:占4个字节,用来标记数据段的顺序,TCP把连接中发送的所有数据字节都编上一个序号,第一个字节的…

    2017-09-03