N26-第六周作業

vim編輯器的使用

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

輸入模式–>編輯模式
ESC

編輯模式–>末行模式
:
末行模式–>編輯模式
ESC

關閉文件:
ZZ:保存并推出
:q 退出
:q! 強制退出,不保存此前的編輯操作
:wq 保存并退出
:x 保存并退出
:w /PATH/TO/SOMEFILE

光標跳轉:

字符間跳轉
h(左),l(右)
j(下),k(上)
#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:替換光標所在處的字符;

刪除命令:
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

撤銷操作:
u:撤銷此前的操作;
#u:撤銷此前的#個操作

撤銷此前的撤銷:
Ctrl+r

重復執行 前一個編輯操作:
.

vim自帶的練習教程:vimtutor

vim末行模式:
內建的命令行接口

(1)地址定界
   :start_pos[,end_pos]
    #:特定的第#行,例如5即第5行;
    .:當前行;
    $:最后一行;
    #,#:指定行范圍,左側為起始行,右側為結束行;
    #,+#: 指定行范圍,左側為起始行絕對編號,右側為相對左側行號的偏移量;例如:3,+7
    .,$-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
s/要查找的內容/替換為的內容/修飾符
要查找的內容:可使用正則表達式;
替換為的內容:不能使用正則表達式,但是可以引用;
如果“要查找的內容”部分在模式中使用分組符號:在“替換為的內容”中使用向后引用;
直接引用查找模式匹配到的全部文本,要用&符號
修飾符:
i:忽略大小寫;
g:全局替換,意味著一行中如果匹配到多次,則均替換;
vim的多文件功能:
多文件:
vim FILE1 FILE2 …

大文件間切換:
:next 下一個
:prev 上一個
:first 第一個
:last 最后一個

退出所有文件:
:wqall 保存所有文件并推出;
:wall 保存所有文件
:qall 退出所有文件

多窗口:
-o:水平分隔窗口
-O:垂直分隔窗口

在窗口間切換:Ctrl+w,ARROW

注意:單個文件也可以分隔為多個窗口進行查看:
Ctrl+w,s:水平分隔窗口
Ctrl+w,v:垂直分割窗口
1、復制/etc/rc.d/rc.sysinit文件至/tmp目錄,將/tmp/rc.sysinit文件中的以至少一個空白字符開頭的行的行首加#;

[root@zhao-centos6 ~]# sed 's@^[[:space:]]@#@' /tmp/rc.sysinit

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

[root@zhao-centos6 ~]# sed 's%^[[:space:]]\+%%' /tmp/grub.conf

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

[root@zhao-centos6 ~]# sed 's%^#[[:space:]]\+%%' /tmp/rc.sysinit 

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

[root@zhao-centos6 ~]# sed '1,3i\#' /tmp/grub.conf 

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

[root@zhao-centos6 ~]# sed -e 's@enabled=0@enabled=1@' -e 's@gpgcheck=0@gpgcheck=1@' /etc/yum.repos.d/CentOS-Media.repo 

-e用于多處編輯

6、每4小時執行一次對/etc目錄的備份,備份至/backup目錄中,保存的目錄名為形如etc-201504020202

mkdir /backup
crontab -e
1 */4 * * * cp /etc/* /backup/etc\-$(date+"%Y%m%d%h%M")

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

mkdir -p /backup/messages_logs
crontab -e
1 1 * * 2,4,6 cp /var/log/messages /backup/messages_logs/messages\-$(date+"%Y%m%d%")

前面必須標注時間,不然會變成每小時每分鐘執行

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

mkdir -p /stats/memory.txt
crontab -e
1 */2 * * * grep "^S" >> /status/memory.txt

必須加分,不然會變成每兩小時每分執行一次。

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

crontab -e
1 */2 * * 1-5 echo "howdy"

腳本編程練習
10、創建目錄/tmp/testdir-當前日期時間; 

[root@zhao-centos6 ~]# mkdir -p /tmp/testdir\-$(date +"%Y%m%d%H%M")

11、在此目錄創建100個空文件:file1-file100

#!/bin/bash
for i in {1..100};do
        touch file"$i"
done  

12、顯示/etc/passwd文件中位于第偶數行的用戶的用戶名;

#!/bin/bashdeclare -i num=`wc -l /etc/passwd | wc -l /etc/passwd | cut -d' ' -f1`declare -i i=0while [ $i -lt $num ];dosed -n ''$i'p' /etc/passwd | cut -d: -f1i=$[ $i+2 ]done

13、創建10用戶user10-user19;密碼同用戶名;

#!/bin/bashfor i in {1..19};do        useradd user"$i"        echo user"$i" | passwd --stdin user"$i"i=$[ $i+1 ]done

14、在/tmp/創建10個空文件file10-file19; 

#!/bin/bashcd /tmpdeclare -i i=10for i in {10..19};do        touch file"$i"        i=$[ $i+1 ]done

15、把file10的屬主和屬組改為user10,依次類推。

#!/bin/bashdeclare -i i=10for i in {10..19};dochown user"$i" file"$i"chgrp user"$i" file"$i"i=$[ $i+1 ]done

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

(0)
lafengjinzilafengjinzi
上一篇 2017-03-13 22:27
下一篇 2017-03-14 16:09

相關推薦

  • Linux里的用戶與組

    任何事務的進行都離不開管理,脫離了管理的系統將會是一團亂麻。今天就來講講Linux里的用戶與組的管理 首先,用戶與組不會憑空出現,必須得是系統本身或人為創建的 。     所以,系統創建的就叫系統用戶.系統組,用戶創建的就是普通用戶.普通組。 useradd  創建用戶 -u 創建用戶并指定用戶的UID -g…

    2017-07-30
  • 編程語言編年史

          我們都知道,編程語言是一組用來定義計算機程序的語法規則。它是一種被標準化的交流語言,用來向計算機發出指令。一種計算機語言讓程序員能夠準確地定義計算機所需要使用的數據,并精確地定義在不同情況下所應當采取的行動。盡管人們多次試圖創造一種通用的程序設計語言,卻沒有一次嘗試是成功的。之所以有那么多種不同的編程語言存在的原因是…

    Linux干貨 2017-03-30
  • Redhat的Linux產品版本AS/ES/WS的聯系與區別

    Redhat 有兩大Linux產品系列,其一是免費的Fedora Core系列主要用于桌面版本,提供了較多新特性的支持。另外一個產品系列是收費的Enterprise系列,這個系列分成:AS/ES/WS等分支,他 們都是redhat企業級Linux,簡稱為 RHEL AS 是超級服務器版(Advanced Server),他在標準Linux內核的基礎上,做了性…

    Linux干貨 2015-03-20
  • OSI和TCP/IP

            我們生活中各方面都離不開網絡,那網絡究竟是什么東西呢?它是怎么做到讓在不同地點的人無視空間距離完成通信的呢?首先我們來了解一下網絡的基本概念。網絡是由節點和連線構成,表示諸多對象及其相互聯系。在數學上,網絡是一種圖,一般認為專指加權圖。網絡除了數學定義外,還有具體…

    2017-09-02
  • 關于文本處理工具之SED

                                                      &nbsp…

    學員作品 2016-08-10
  • varnish4 基礎實戰

    實驗環境 node1 192.168.0.8 varnish服務器 node2 192.168.0.3 動態web node3 192.168.0.7 靜態web node1安裝varnish ##安裝varnish yum源  # wget http://repo.varnish-cache.org/redhat/v…

    Linux干貨 2016-11-15
欧美性久久久久