第六周作業

請詳細總結vim的使用

模式轉換

編輯模式:默認模式
    編輯模式-->輸入模式
        i:insert,在光標所在處插入
        a:append,在光標所在處后方輸入
        o:在光標所在處下方新增一行
        I:在光標所在行的行首插入
        A:在光標所在行的行尾輸入
        O:在光標所在行的上方插入一行

    輸入模式-->編輯模式
        ESC

    編輯模式-->末行模式
        :

光標跳轉:

字符間跳轉
    h--左,j--下,k--上,l--右
    #COMMAND    :跳轉由#指定的個數的字符
單詞間跳轉
    w:下一個單詞的詞首
    b:當前或前一個單詞的詞首
    e:當前或后一個單詞的詞尾
    #COMMAND    :跳轉由#指定的個數的單詞

行首行尾跳轉
    ^:跳轉至行首的第一個非空白字符
    0:跳轉至行首
    $:跳轉至行尾

行間跳轉
    #G:跳轉至由#指定的行
    1G,gg:跳轉到第一行
    G:最后一行

翻屏:
    ctrl+f:向文件尾翻一屏
    ctrl+b:向文件首部翻一屏
    ctrl+d:尾部半屏
    ctrl+u:首部半

vim的編輯命令

字符編輯
    x:刪除光標所在處的字符
    #x:刪除光標所在處起始的#個字符
    xp:交換光標所在字符于其后面字符的位置
替換命令
    r:替換光標所在處的字符

刪除命令
    d:刪除命令,可結合光標跳轉字符,實現范圍刪除
        d$,d0,d^,dw,dd,    都可以加數字,#dd,刪除多行
    粘貼命令
        p:緩沖區的內容如果為整行,則粘貼在當前光標所在行的下方,否則,則粘貼至當前光標所在處的后方
        P:緩沖區的內容如果為整行,則粘貼在當前光標所在行的上方,否則,則粘貼至當前光標所在處的前方
    復制命令
        y:復制,工作行為相似于d命令,
            y$,y^,y0,yy,yw
改變命令:
    同d命令,但是修改完會直接進入輸入模式

vim末行模式

內建的命令行接口

1.地址定界
    :start_post[,end_post]
        #:特定的第#行
        .:當前行
        #,#:指定行范圍,左側為起始行,右側為結束行
        #,+#:指定行范圍,左側為起始行,右側為相對左側行號的偏移量
            .,$:當前行到最后一行
            %:全文
            /pattern/:從光標所在處啟示向文件尾部第一次被模式所匹配到的行
                /first/,$
        /pat1/,/pat2/:從光標所在處氣勢,第一次由pat1匹配到的行,至第一次由pat2匹配到的行結束之間的所有行

    可用編輯命令一同使用,實現編輯操作:
        d,y,c
        w /PATH/TO/SOMEFILE:將范圍內的文本保存至指定的文件中
        r /PATH/FROM/FOMEFILE:將指定的文件中文本讀取并插入至指定位置

2.查找
    /PATTERN:從當前光標所在處向文件尾部查找能夠被當前模式匹配到的所有字符串
    ?PATTERN:從當前光標所在處向文件首部查找能后被當前模式匹配到的所有字符串
        n:下一個,與命令方向相同
        N:上一個,與命令方向相反

3.查找與替換
    s:末行模式的命令,使用格式
        s/要查找的內容/替換為的內容/修飾符
            要查找的內容:可使用正則表達式
            替換為的內容:不可使用正則表達式,但是可以引用
            修飾符:
                i:忽略大小寫
                g:全局替換,一行中如果匹配到多次,則均替換
        可把分隔符替換為其他非常用字符
            s@@@    或s###
        &符號可以直接引用前面匹配的內容
        實例:
            %s@\<t\([[:alpha:]]\+\)\>@T\1@g
            %s@\<t[[:alpha:]]\+\>@&hxjagf@gi
            %s@^#@@g
            %s@\(enabled|gpgcheck\)=0@\1=1@g

1、復制/etc/rc.d/rc.sysinit文件至/tmp目錄,將/tmp/rc.sysinit文件中的以至少一個空白字符開頭的行的行首加#;

    ggyG    :w /tmp/rc.sysinit    :%s@^[[space:]]\+@#&@g

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

    ggyG    :w /tmp/grub.conf    :1s/^[[:space:]]//g

3、刪除/tmp/rc.sysinit文件中的以#開頭,且后面跟了至少一個空白字符的行行的#和空白字符

    :%s@^#[[:space:]]\+@@g

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

    :1,3s@^.*@#&@g

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 * * * /bin/cp -R /etc/ /backup/etc-$(date +%Y%m%d%H%M)/

7、每周2,4,6備份/var/log/messages文件至/backup/messages_logs/目錄 
中,保存的文件名形如messages-20150402

0 0 * * 2,4,6 /bin/cp /var/log/messages /backup/messages_logs/messages-$(date +%Y%m%d%H%M)

8、每天每兩小時取當前系統/proc/meminfo文件中的所有以S開頭的信息至/stats/memory.txt文件中

0 */2 * * * /bin/grep "^S.*" /proc/meminfo >> /stats/memory.txt

9、工作日的工作時間內,每兩小時執行一次echo "howdy"

0 9-18/2 * * 1-5 /bin/echo "howdy"

腳本編程練習 
10、創建目錄/tmp/testdir-當前日期時間; 
11、在此目錄創建100個空文件:file1-file100 
12、顯示/etc/passwd文件中位于第偶數行的用戶的用戶名;

#!/bin/bash
DIR=$(date +%Y%m%d)[ -d /tmp/testdir-$DIR ] || mkdir /tmp/testdir-$DIR
for i in {1..100}; do
    touch /tmp/testdir-$DIR/file$i
done
sed -n '2~2p' /etc/passwd | cut -d: -f1

原創文章,作者:lanpang,如若轉載,請注明出處:http://www.www58058.com/68796

(0)
lanpanglanpang
上一篇 2017-02-15 17:33
下一篇 2017-02-15 20:48

相關推薦

  • 文件查找find和locate

            在Linux這個一切皆文件的系統中怎么能快速和精確的查找到文件,是我們必不可少的技能。而文件查找的命令可以讓我們在很短的時間內在文件系統中找到我們要查找的文件。這就是我們要掌握的,因此我來介紹一下文件查找的這兩個命令locate和find。 文件查找:在文件系統上…

    Linux干貨 2016-08-24
  • linux基礎之磁盤管理

    linux基礎之磁盤管理 學習linux,數據維護和管理是重中之重,而數據大部分存放在硬盤當中,因此,熟練掌握磁盤的使用和管理是運維人員的基礎要求。那么,linux系統包括哪些知識點呢? 下面,我們就詳細闡述下Linux中磁盤的分區、格式化,以及一些磁盤的高級用法:磁盤配額、RAID陣列和LVM 一、硬盤 隨著技術的進步,人類社會的不斷發展。硬盤也經歷了幾代…

    Linux干貨 2017-03-19
  • 馬哥教育網絡班21期+第四周課程練習

    1、復制/etc/skel目錄為/home/tuser1,要求/home/tuser1及其內部文件的屬組和其它用戶均沒有任何訪問權限; [root@localhost /]# cp -r /etc/skel /home/tuser1 [root@localhost /]# chmod&nb…

    Linux干貨 2016-07-22
  • Linux用戶和組的基礎概念

    用戶,組和權限管理   Multi-tasks,  Multi-Users 每個使用者:    用戶標識,密碼:    認證:Authentication    授權:Authorization    審計:Audition    3A 組…

    Linux干貨 2016-12-21
  • Week9’s homework

    Week9's homework 1、寫一個腳本(1)判斷當前系統上所有用戶的shell是否為可登錄shell(即用戶的shell不是/sbin/nologin)(2)分別統計兩類用戶的個數;通過字符串比較來實現。 #!/bin/bash # for i in $(cat /etc/passwd |…

    Linux干貨 2016-12-24
  • 使用haproxy代理LAMP、LNMP 實現WordPress發布

    haproxy簡介 HAProxy是專業的反向代理軟件,它可以支持4層和7層代理服務。其配置包含一下幾個配置段: global:全局設置,通常與操作系統有關 defaults:配置默認參數,可以被frontend、backend、listen組件利用 frontend:接收親請求的前虛擬節點 backend:后端服務集群的配置,一個backend可以對應多個…

    2017-05-17
欧美性久久久久