马哥教育网络21期+第六周练习博客

马哥教育网络21期+第六周练习博客

请详细总结vim编辑器的使用并完成以下练习题
    VIM编辑器:
        vi:Visual Interface 文本编辑器
        文本数据:纯ASCII或Unicode
文件编辑器种类:
    行编辑器:sed
    全屏编辑器:nano
vim:模式化编辑器
    常用模式:
        编辑模式-->命令模式
        输入模式
        末行模式:内置的命令行接口

打开文本文件;
    #vim [OPTION] ....
     +#:打开文件后,直接让光标处于第#行的行首;
     +/PATTERN:打开文件后,直接让光标处于第一个被PATTERN匹配到的行首;

模式转换:
    编辑模式-->输入模式
    i:在光标所在处前转换为输入模式;
    a:在光标所在后面转入输入模式;
    o:在当前光标所在行的下方打开一个新行,并转为输入模式;
    I:在当前光标所在行的行首输入;
    A:在当前光标所在行的行尾输入;
    O:在当前光标所在行的上方打开一个新行,并转为输入模式;

模式之间的互相转换:
    输入模式-->编辑模式-->ESC
    编辑模式-->末行模式-->:
    末行模式-->编辑模式-->:ESC

关闭并退出:
    :q 退出
    :q!强制退出
    :wq保存退出
    :x 保存退出
    :w /PATH/TO/保存在指定文件

光标跳转:
    字符间的跳转:
    h:左
    l:右
    j:下
    k:上

#COMMAND:10l:跳转由#指定的个数的字符:

单词间进行跳转:
    w:跳至下个单词的词首
    e:跳转至下一个单词的词尾
    b:跳至当前词的词首

#COMMAND:由#指定一次跳转的单词数

行内的行首行尾跳转:
    ^:跳转至行首的第一个非空白字符;
    0:跳转至行首;
    $:跳转至行尾;

行间移动:
    #G:跳转至由#指定行;
    G:最后一行;
    1G或gg:第一行;
句间移动:
    (或)
段落件移动:
    {或}

VIM的编辑命令:

字符编辑:
x:删除光标处单个字符:
#x:删除光标所在处起始的#个字符;
xp:交换光标所在处的字符及其后面字符的位置;

删除命令:
d:删除命令,可结合光标跳转字符,实现范围删除;
例如:d$,d^,d0
dd:删除光标所在的行;
    #dd:多行删除;

粘贴命令:
P:缓冲区中存储的如果为正行内容,则粘贴当前所在行的下方,否则粘贴至当前光标所在处的后面;
P:缓冲区中存储的如果为整行内容,则粘贴当前所在行的上方:否则粘贴至当前光标所在处的前面

复制命令:
y:复制,工作行为相似于d命令;
yy:复制行;#yy:复制多行;

改变命令:
c:修改
编辑模式-->输入模式
    c$:行尾修改从光标所在地删除行尾;
    c^:行首修改从光标所在地删除行首;
    c0:行首修改从光标所在地删除行首;
    cb:修改指定单词;
    ce:
    cw:

其他编辑操作:

可视化模式;
    v:按字符选定;
    V:按行选定;
❤经常结合编辑命令❤

撤销此前的编辑:
    u:撤销此前的操作;
    #u:撤销指定次数的操作;

撤销此前的撤销:
    Crtl+r

翻屏操作:
    Crtl+f:向文件尾部翻一屏;
    Ctrl+b:向文件首部翻一屏;
    Crtl+d:向文件尾部翻半屏;
    Crtl+u:向文件首部翻半屏;

vim中的末行模式:

内置命令行接口
(1)地址定界-->:start_pos,end_pos
#:具体第#行,例如2,100;
#,#:从左侧#表示行起始,到右侧#表示行结尾:
#,+#:1,+3:从左侧#表示的行起始,加上右侧#表示的行数:
.:当前行:
$:最后一行:
%:全文,相当于1,$

/pat1/,/pat2/:
从第一次被pat1模式匹配到的行开始,一直到第一次pat2匹配到的行结束:

使用方式:

后跟一个编辑命令:
    d:在指定输出后进行删除;
    w /PATH/TO/SOMEWHERE:将范围内的行另存至指定文件中;
    r /PATH/FROM/SOMEFILE: 在指定位置插入指定文件中的所有内容;

(2)查找:
    /PATTERN:从当前光标所在处向文件尾部查找
    ?PATTERN:从当前光标所在处向文件首部查找:
        n:与命令同方向:
        N:与命名反方向:

(3)查找并替换:
    s:在末行模式下完成查找替换操作
    s/要查找的内容/替换为的内容/修饰符
        要查找的内容:可使用模式
        替换为的内容:不能使用模式,但可以使用\1,\2...等后向引用符号,还可以使用“&”引用前面查找时查找到的整个内容:
        修饰符:
            i:忽略大小写
            g:全局替换:默认情况下,每一行只替换第一次出现:
            查找替换中的分隔符/可替换为其他字符,例如:
            s@@@
            s###

vim的多文件模式:

vim FILE1 FILE2 FILE3 ...
    :next 下一个;
    :prev 前一个;
    :first 第一个;
    :last 最后一个;
    :wall 保存所有;
    :qall 退出所有;

窗口分割模式:

vim -o | -O FILE1 FILE2...
    -O:垂直分割
    -o:水平分割
    在窗口间切换:Ctrl+w,箭头向下的箭头
单文件窗口分割:
    Ctrl+w,s :split,水平分割;
    Ctrl+w,v:vertical 垂直分割;

定制VIM的工作特性:

配置文件:
    全局:/etc/vimrc
    个人:~/.vimrc
末行:当前vim进程有效
    (1)显示或取消行号
        set number,简写为set nu
        取消显示:set nonumber,简写为set nonu
    (2)括号匹配
        匹配:set showmatch ,简写为set sm
        取消:set nosm
    (3)自动缩进
        启用:set ai
        禁用:set noai
    (4)高亮搜索
        启用:set hlsearch
        禁用:set nohisearch
    (5)语法高亮
        启用:syntax on
        禁用:syntax off
    (6)忽略字符的大小写
        启用:set ic
        不忽略:set noic

获取帮助:
    :help 
    :help subject

练习:

1、复制/etc/rc.d/rc.sysinit文件至/tmp目录,将/tmp/rc.sysinit文件中的以至少一个空白字符开头的行的行首加#;
[root@wanghongkai ~]# cp /etc/rc.d/rc.sysinit /tmp/
[root@wanghongkai ~]#  sed 's/^[[:space:]]\+/#/' /tmp/rc.sysinit


2、复制/boot/grub/grub.conf至/tmp目录中,删除/tmp/grub.conf文件中的行首的空白字符;
[root@wanghongkai ~]# cp /boot/grub/grub.conf /tmp
[root@wanghongkai ~]# sed 's/^[[:space:]]\+//' /tmp/grub.conf


3、删除/tmp/rc.sysinit文件中的以#开头,且后面跟了至少一个空白字符的行行的#和空白字符;
[root@wanghongkai ~]# sed 's@^#[[:space:]]\+@@' /tmp/rc.sysinit


4、为/tmp/grub.conf文件中前三行的行首加#号;
[root@wanghongkai ~]# sed 1,3's/^/#/' /tmp/grub.conf


5、将/etc/yum.repos.d/CentOS-Media.repo文件中所有的enabled=0或gpgcheck=0的最后的0修改为1;
[root@wanghongkai ~]#sed 's/=0/=1/' /etc/yum.repos.d/CentOS-Media.repo

6、每4小时执行一次对/etc目录的备份,备份至/backup目录中,保存的目录名为形如etc-201504020202;
[wostop@wanghongkai ~]$ crontab -l
0 */4 * * * cp -ri /etc /backup/etc-'date +%Y%m%d'


7、每周2,4,6备份/var/log/messages文件至/backup/messages_logs/目录中,保存的文件名形如messages-20150402;
[wostop@wanghongkai etc]$ crontab -l
1 * * * 2,4,6 cp -r /var/log/messages /backup/messages_logs/messages-`date +%F%T`


8、每天每两小时取当前系统/proc/meminfo文件中的所有以S开头的信息至/stats/memory.txt文件中;
[wostop@wanghongkai etc]$ crontab -l
0 */2 * * * egrep "^(S|s)" /proc/meminfo >> /stats/memory.txt



9、工作日的工作时间内,每两小时执行一次echo "howdy";
[wostop@wanghongkai etc]$ crontab -l
0 */2 * * 1,2,3,4,5 echo "howdy"

脚本编程练习

10、创建目录/tmp/testdir-当前日期时间;
#!/bin/bash
mkdir /tmp/testdir-`date +%F%T`


11、在此目录创建100个空文件:file1-file100;
#!/bin/bash
#
for i in {1..100};do
    mkdir /tmp/file$i &> /dev/null
done


12、显示/etc/passwd文件中位于第偶数行的用户的用户名;
#!/bin/bash
#
sed -n 'n;p' /etc/passwd | cut -d':' -f1

[root@wanghongkai ~]# ./1.sh 
bin
adm
sync
halt
uucp

13、创建10用户user1-user10;密码同用户名;
#!/bin/bash
#
for i in {1..10};do
    if id user$i $> /dev/null;then
       echo "user$i cunzai."
    else
        useradd user$i && echo "user$i" | passwd --stdin user$i
    fi
done
echo "YONGHU user$i JIANLI"


14、在/tmp/创建10个空文件file10-file19;
[root@wanghongkai ~]# cat 1.sh 
#!/bin/bash
#
for i in {10..19};do
    mkdir -p /tmp/file$i
done


15、把file10的属主和属组改为user10,依次类推。
[root@wanghongkai ~]# cat 1.sh 
#!/bin/bash
#
for i in {11..19};do
    chown user$i /tmp/file$i && chgrp user$i /tmp/file$i
done

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

评论列表(1条)

  • 马哥教育
    马哥教育 2016-08-17 15:35

    写的很好,排版也很棒,加油,7不对