【運維】Shell — 快速上手Shell腳本

1.Shell概述

shell腳本是利用shell的功能所寫的一個【程式(program)】。這個程式是使用純文本文件,將一些shell的語法與命令(含外部命令)寫在裡面,搭配正則表達式、管道命令與數據流重定向等功能,以達到我們所想要的處理目的。

通俗地說,shell腳本可以簡單地被看成是批處理文件,也可以被說成是一個程式語言,且這個程式語言由於都是利用shell與相關工具命令,所以不需要編譯即可執行。此外,它還擁有不錯的排錯(debug)工具,能夠幫助系統管理員快速地管理好主機。

 

2.Shell腳本入門

1.腳本格式

腳本以#!/bin/bash開頭(指定解析器)

①編寫一個helloworld的shell腳本:

#!/bin/bash
echo "hello shell!"

 

②執行腳本並輸出:

[root@yifcloud workspace]# sh hello.sh  #本質是bash解析器幫你執行腳本,不需要執行許可權
hello shell!

#以絕對路徑執行腳本並輸出
[root@yifcloud workspace]# chmod 777 hello.sh  
[root@yifcloud workspace]# ll
total 4
-rwxrwxrwx 1 root root 34 Apr 21 15:19 hello.sh
[root@yifcloud workspace]# /myshell/workspace/hello.sh   #腳本自己需要執行,需要執行許可權 
hello shell!
#以相對路徑執行腳本並輸出
[root@yifcloud workspace]# ./hello.sh 
hello shell!

 

③編寫一個多行的Shell腳本:

#在/home/fengye目錄下創建一個banzhang.txt文件;並向文件中寫入"I love shell"語句
#!/bin/bash
cd /home/fengye/
touch banzhang.txt
echo "I love shell" >> banzhang.txt

 

3.Shell中的變數

3.1.系統變數

1.常用的系統變數

$HOME、$PWD、$SHELL、$USER等

[root@yifcloud ~]# echo $HOME  #列印家目錄
/root
[root@yifcloud ~]# echo $PWD    #列印當前目錄
/root
[root@yifcloud ~]# echo $SHELL   #輸出shell bash
/bin/bash
[root@yifcloud ~]# echo $USER  #輸出當前用戶
root

 

3.2.自定義變數

1.基本語法

(1)定義變數:變數=值

(2)撤銷變數:unset 變數

(3)聲明靜態變數:readonly變數,注意:不能unset

[root@yifcloud ~]# p1=1  #定義變數,注意:聲明變數與=之間不能有空格!!!
[root@yifcloud ~]# echo $p1
1
[root@yifcloud ~]# p1=2 #給變數賦值
[root@yifcloud ~]# echo $p1
2
[root@yifcloud ~]# unset p1  #撤銷變數
[root@yifcloud ~]# echo $p1

[root@yifcloud ~]# readonly p2=2  #聲明靜態變數,靜態變數不能unset
[root@yifcloud ~]# echo $p2
2
[root@yifcloud ~]# unset p2
-bash: unset: p2: cannot unset: readonly variable

 

2.變數定義規則

(1)變數名稱可以由字母、數字和下劃線組成,但是不能以數字開頭,環境變數名建議大寫。

(2)等號兩側不能有空格。

(3)在bash中,變數默認類型都是字元串類型,無法直接進行數值運算。

(4)變數的值如果有空格,需要使用雙引號或單引號括起來。

例如:

[root@yifcloud ~]# C=1+2
[root@yifcloud ~]# echo $C
1+2
[root@yifcloud ~]# D=I love programing shell
-bash: love: command not found
[root@yifcloud ~]# D="I love programing shell"
[root@yifcloud ~]# echo $D
I love programing shell

 

(5)可以把變數提升為全局環境變數,可供其它Shell程式使用。

語法:export 變數名

[root@yifcloud fengye]# D="I love programing shell"
[root@yifcloud fengye]# echo $D
I love programing shell

#在hello.sh文件中增加echo $D
#!/bin/bash
echo "hello shell!"
echo $D

[root@yifcloud fengye]# vim /myshell/workspace/hello.sh 
[root@yifcloud fengye]# cd /myshell/workspace/
[root@yifcloud workspace]# sh hello.sh 
hello shell!

#定義全局環境變數之後
[root@yifcloud workspace]# export D="I love python"
[root@yifcloud workspace]# sh hello.sh 
hello shell!
I love python

 

3.3.特殊變數:$n

1.基本語法

$n(功能描述:n為數字,$0代表該腳本名稱,$1-$9代表第一到第九個參數,十以上的參數(包含十),需要用大括弧包含,如${10})

[root@yifcloud workspace]# touch parameter.sh
[root@yifcloud workspace]# vim parameter.sh   #在parameter.sh中編寫shell語句如下:
#!/bin/bash
echo "$0 $1 $2 $3"

[root@yifcloud workspace]# bash parameter.sh 
parameter.sh   
[root@yifcloud workspace]# bash parameter.sh zhangsan
parameter.sh zhangsan  
[root@yifcloud workspace]# bash parameter.sh zhangsan lisi
parameter.sh zhangsan lisi 
[root@yifcloud workspace]# bash parameter.sh zhangsan lisi wangwu
parameter.sh zhangsan lisi wangwu
[root@yifcloud workspace]# bash parameter.sh zhangsan lisi wangwu zhaoliu
parameter.sh zhangsan lisi wangwu

 

3.4.特殊變數:$#

1.基本語法

$#(功能描述:獲取所有輸入參數個數,常用於循環)。

[root@yifcloud workspace]# vim parameter.sh 
#使用$#列印輸出變數的個數,parameter.sh內容如下:
#!/bin/bash
echo $#

[root@yifcloud workspace]# bash parameter.sh 
0
[root@yifcloud workspace]# bash parameter.sh zhangsan 
1
[root@yifcloud workspace]# bash parameter.sh zhangsan lisi
2
[root@yifcloud workspace]# bash parameter.sh zhangsan lisi wangwu
3

 

3.5.特殊變數:$*、$@

1.基本語法

$*:

(功能描述:這個變數代表命令行中所有的參數,$*把所有的參數看成一個整體)。

$@:

(功能描述:這個變數也代表命令行中所有的參數,不過$@把每個參數區分對待)。

具體用法區別見:6.3.for循環 — 演示$*與$@的區別:

 

3.6.特殊變數:$?

1.基本語法

$?(功能描述:最後一次執行的命令的返回狀態。如果這個狀態的值為0,證明上一個命令正確執行;如果這個變數的值為非0(具體是哪個數,由命令自己來決定)),則證明上一個命令執行不正確了。)

[root@yifcloud workspace]# bash hi
bash: hi: No such file or directory
[root@yifcloud workspace]# bash parameter.sh 
0
[root@yifcloud workspace]# cd .
[root@yifcloud workspace]# echo $?
0
[root@yifcloud workspace]# $?
-bash: 0: command not found
[root@yifcloud workspace]# echo $?
127

 

4.運算符

1.基本語法

(1)「$((運算式))」或「$[運算式]」

(2)expr +,-,*,/,% ,表示加,減,乘,除,取余

注意:expr運算符間要有空格

#expr一步完成計算
[root@yifcloud workspace]# expr `expr 2 + 3` \* 4
20
#採用$[運算式]方式
[root@yifcloud workspace]# s=$[(2+3)*4]
[root@yifcloud workspace]# echo $s
20

 

5.條件判斷

1.基本語法

[condition](注意condition前後要有空格)

注意:條件非空即為true,[param]返回true,[]返回false。

2.常用判斷條件

(1)兩個整數之間比較

= 字元串比較

-lt 小於(less than) -le 小於等於(less equal)

-eq 等於(equal) -gt 大於(greater than)

-ge 大於等於(greater equal) -ne 不等於(Not equal)

(2)按照文件許可權進行判斷

-r 有讀的許可權(read) -w 有寫的許可權(write)

-x 有執行的許可權(execute)

(3)按照文件類型進行判斷

-f 文件存在並且是一個常規的文件(file)

-e 文件存在(existence) -d 文件存在並是一個目錄(directory)

 

示例如下:

[root@yifcloud workspace]# [ panda = PANDA ]
[root@yifcloud workspace]# echo $?
1
[root@yifcloud workspace]# [ 23 -ge 22 ]
[root@yifcloud workspace]# echo $?
0
[root@yifcloud workspace]# [ 23 -gt 22 ]
[root@yifcloud workspace]# echo $?
0
[root@yifcloud workspace]# [ -w hello.sh ]
[root@yifcloud workspace]# echo $?
0
[root@yifcloud workspace]# [ -e /home/fengye/cls.txt ]
[root@yifcloud workspace]# echo $?
1
[root@yifcloud workspace]# [ -e /home/fengye/banzhang.txt ]
[root@yifcloud workspace]# echo $?
0

 

(4)多條件判斷(&&表示前一條命令執行成功時,才執行後一條命令,||表示上一條命令執行失敗後,才執行下一條命令)

[root@yifcloud workspace]# [ condition ] && echo OK || echo notOK
OK
[root@yifcloud workspace]# [ condition ] && [ ] || echo notOK
notOK

 

6.流程式控制制

6.1.if 判斷

1.基本語法

if[ 條件判斷式 ];then

程式

fi

#!/bin/bash
if [ $1 -eq 1 ];then
    echo "this is zhangsan"
elif [ $1 -eq 2 ];then
    echo "this is lisi"
fi

 

執行上述語句:

[root@yifcloud workspace]# bash if.sh 2
this is lisi

或者

if[ 條件判斷式 ]

then

程式

fi

 

#!/bin/bash
if [ $1 -eq 1 ]
     then
        echo "this is zhangsan"
elif [ $1 -eq 2 ]
     then
        echo "this is lisi"
fi

 

注意事項:

(1)[ 條件判斷式 ],中括弧和條件判斷式之間必須有空格

(2)if後要有空格

 

6.2.case語句

1.基本語法

case $變數名 in

“第一個變數內容”)

程式段

;;

“第二個變數內容”)

程式段

;;

*)

exit 1

;;

esac

 

示例:

#!/bin/bash    
case $1 in        <==關鍵字為case,還有變數前有美元符號
  1)               <==每個變數內容建議用雙括弧括起來,關鍵字則為右圓括弧
        echo "this is zhangsan"
        ;;           <==每個類別結尾使用兩個連續的分號來處理
  2)
        echo "this is lisi"
        ;;
  *)               <==最後一個變數內容都會用*來代表所有其他值
        echo "this is other"     <==不包含第一個變數內容與第二個變數內容的其它程式執行段
        ;;
esac                         <==最終的case結尾,case反過來寫

 

執行:

[root@yifcloud workspace]# bash case.sh 1
this is zhangsan
[root@yifcloud workspace]# bash case.sh 2
this is lisi
[root@yifcloud workspace]# bash case.sh 3
this is other

 

6.3.for循環

1.基本語法

for (( 初始值;循環控制條件;變數變化 ))

do

程式

done

#測試從1加到100的值
#!/bin/bash
s=0
for ((i=1;i<=100;i++))
do
        s=$[$s + $i]
done
echo $s

 

2.基本語法2

for 變數 in 值1 值2 值3…

do

程式

done

#!/bin/bash
for i in $*
do
        echo "banzhang xihuan $i"
done
echo "========================="
for j in $@
do
        echo "banzang xihuan $j"
done

 

執行:

[root@yifcloud workspace]# bash for2.sh zhangsan lisi wangwu
banzhang xihuan zhangsan
banzhang xihuan lisi
banzhang xihuan wangwu
=========================
banzang xihuan zhangsan
banzang xihuan lisi
banzang xihuan wangwu

 

演示$*與$@的區別:

#!/bin/bash
for i in "$*"
do
        echo "banzhang xihuan $i"
done
echo "========================="
for j in "$@"
do
        echo "banzang xihuan $j"
done

 

執行:

[root@yifcloud workspace]# bash for2.sh zhangsan lisi wangwu
banzhang xihuan zhangsan lisi wangwu
=========================
banzang xihuan zhangsan
banzang xihuan lisi
banzang xihuan wangwu

 

6.4.while循環

1.基本語法

while [ 條件判斷式 ]

do

程式

done

示例:

#!/bin/bash
s=0
i=1
while [ $i -le 100 ]
do
        s=$[$i+$s]
        i=$[$i+1]
done
echo $s 

 

7.read讀取控制台輸入

1.基本語法

read(選項)(參數)

選項:

-p:指定讀取值時的提示符

-t:指定讀取值時等待的時間(秒)

參數:

變數:指定讀取值的變數名

#!/bin/bash
read -t 7 -p "Enter your name in 7 senconds" NAME
echo $NAME

 

測試:

[root@yifcloud workspace]# bash read.sh 
Enter your name in 7 senconds xiaozi
xiaozi

 

8.Shell函數

8.1.系統函數

1.basename基本語法

basename [string / pathname] [suffix]

(功能描述:basename命令會刪掉所有的前綴包括最後一個(’/’)字元,然後將字元串顯示出來。)

選項:suffix為後綴,如果suffix被指定了,basename會將pathname或string中的suffix去掉。

 

示例:

截取該/home/fengye/banzhang.txt路徑的文件名稱

[root@yifcloud workspace]# basename /home/fengye/banzhang.txt 
banzhang.txt
[root@yifcloud workspace]# basename /home/fengye/banzhang.txt .txt
banzhang
[root@yifcloud workspace]# basename /myshell/workspace/read.sh 
read.sh
[root@yifcloud workspace]# basename /myshell/workspace/read.sh .sh
read

 

2.dirname基本語法

dirname文件絕對路徑

(功能描述:從給定的包含絕對路徑的文件名中去除文件名(非目錄的部分),然後返回剩下的路徑(目錄的部分))

[root@yifcloud workspace]# dirname /home/fengye/banzhang.txt 
/home/fengye
[root@yifcloud workspace]# dirname /myshell/workspace/read.sh 
/myshell/workspace

 

8.2.自定義函數

1.基本語法

[function] funname[()]

{

Action;

[return int;]

}

funname

 

注意:

必須在調用函數地方之前,先聲明函數,shell腳本是逐行運行。不會像其它語言一樣先編譯。

函數返回值,只能通過$?系統變數獲得,可以顯示加:return返回,如果不加,將以最後一條命令運行結果,作為返回值。return後跟數值n(0-255)

 

示例:

(計算兩個輸入參數的和)

#!/bin/bash

function sum()
{
        s=0
        s=$[$1+$2]
        echo $s
}

read -p "input your parameter1:" P1
read -p "input your parameter2:" P2

sum $P1 $P2

 

執行:

[root@yifcloud workspace]# bash funcsum.sh 
input your parameter1:20
input your parameter2:35
55

 

9.Shell工具

9.1.cut

cut的工作就是「剪」,具體地說就是在文件中負責剪切數據用的。cut命令從文件的每一行剪切位元組、字元和欄位並將這些位元組、字元和欄位輸出。

1.基本用法

cut [選項參數] [filename]

說明:默認分隔符是製表符

 

2.選項參數說明

選項參數 功能
-f 列號,提取第幾列
-d 分隔符,按照指定分隔符分割列

 

 3.示例

(1)數據準備

[root@yifcloud workspace]# touch cut.txt
[root@yifcloud workspace]# vim cut.txt
dong shen
guan zhen
wo   wo
lai  lai
le  le

 

(2)切割cut.txt文件的第一列:

[root@yifcloud workspace]# cut -d " " -f 1 cut.txt 
dong
guan
wo
lai
le

 

(3)切割cut.txt文件的第二、第三列:

[root@yifcloud workspace]# cut -d " " -f 2,3 cut.txt 
shen
zhen
 
 lai
 le

 

(4)在cut.txt文件中切割出guan:

[root@yifcloud workspace]# cat cut.txt
dong shen
guan zhen
wo   wo
lai  lai
le  le
[root@yifcloud workspace]# cat cut.txt|grep guan
guan zhen
[root@yifcloud workspace]# cat cut.txt|grep guan|cut -d " " -f 1
guan

 

(5)選取系統PATH變數值,第2個「:」開始後的所有路徑:

[root@yifcloud workspace]# echo $PATH
/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin
[root@yifcloud workspace]# echo $PATH|cut -d ":" -f 3-   #注意:3-加'-'表示取第三列及以後的數據
/usr/sbin:/usr/bin:/root/bin

 

(6)切割ifconfig後列印的IP地址:

[root@yifcloud workspace]# ifconfig eth0
eth0: flags=4163<UP,BROADCAST,RUNNING,MULTICAST>  mtu 1500
        inet 172.27.0.2  netmask 255.255.240.0  broadcast 172.27.15.255
        inet6 fe80::5054:ff:fe23:5d4b  prefixlen 64  scopeid 0x20<link>
        ether 52:54:00:23:5d:4b  txqueuelen 1000  (Ethernet)
        RX packets 10749720  bytes 3237449326 (3.0 GiB)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 12204171  bytes 2188352910 (2.0 GiB)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0
[root@yifcloud workspace]# ifconfig eth0|grep inet
        inet 172.27.0.2  netmask 255.255.240.0  broadcast 172.27.15.255
        inet6 fe80::5054:ff:fe23:5d4b  prefixlen 64  scopeid 0x20<link>
[root@yifcloud workspace]# ifconfig eth0|grep -m1 "inet"|cut -d "i" -f 2
net 172.27.0.2  netmask 255.255.240.0  broadcast 172.27.15.255
[root@yifcloud workspace]# ifconfig eth0|grep -m1 "inet"|cut -d "i" -f 2|cut -d " " -f 2
172.27.0.2

 

9.2.sed

sed是一種流編輯器,它一次處理一行內容。處理時,把當前處理的行存儲在臨時緩衝區中,稱為「模式空間」,接著用sed命令處理緩衝區中的內容,處理完成後,把緩衝區的內容送往螢幕。接著處理下一行,這樣不斷重複,直到文件末尾。文件內容並沒有改變,除非你使用重定向存儲輸出。

1.基本用法

sed[選項參數] ‘command’ filename

 

2.選項參數說明

選項參數 功能
-e 直接在指令列模式上進行sed的動作編輯

 

3.命令功能描述

命令 功能描述
a 新增,a的後面可以接字元串,在下一行出現
d 刪除
s 查找並替換

 

 4.示例

(1)數據準備

[root@yifcloud workspace]# touch sed.txt
[root@yifcloud workspace]# vim sed.txt 

dong shen
guan zhen
wo  wo
lai  lai

le  le

 

(2)將”mei nv”這個單詞插入到sed.txt第二行下,列印:

[root@yifcloud workspace]# sed "2a mei nv" sed.txt 
dong shen
guan zhen
mei nv
wo  wo
lai  lai
        
le  le

[root@yifcloud workspace]# cat sed.txt  #注意:原文件內容並沒有改變
dong shen
guan zhen
wo  wo
lai  lai
        
le  le

 

(3)刪除sed.txt文件所有包含wo的行

[root@yifcloud workspace]# cat sed.txt 
dong shen
guan zhen
wo  wo
lai  lai
        
le  le
[root@yifcloud workspace]# sed "/wo/d" sed.txt 
dong shen
guan zhen
lai  lai
        
le  le

 

(4)將sed.txt文件中wo替換為ni

/g:表示全部替換,會替換所有的;不加代表只替換匹配到的第一個

[root@yifcloud workspace]# cat sed.txt 
dong shen
guan zhen
wo  wo
lai  lai
        
le  le
[root@yifcloud workspace]# sed "s/wo/ni/" sed.txt 
dong shen
guan zhen
ni  wo
lai  lai
        
le  le
[root@yifcloud workspace]# sed "s/wo/ni/g" sed.txt   
dong shen
guan zhen
ni  ni
lai  lai
        
le  le

 

(5)將sed.txt文件中的第二行刪除並將wo替換為ni

[root@yifcloud workspace]# cat sed.txt 
dong shen
guan zhen
wo  wo
lai  lai
        
le  le
[root@yifcloud workspace]# sed "2d" -e "s/wo/ni/g" sed.txt 
sed: can't read 2d: No such file or directory
dong shen
guan zhen
ni  ni
lai  lai
        
le  le

 

9.3.awk

一個強大的文本分析工具,把文件逐行的讀入,以空格為默認分隔符將每行切片,切開的部分再進行分析處理。

1.基本用法

awk [選項參數] ‘pattern1{action1} pattern2{action2}…’ filename

pattern:表示AWK在數據中查找的內容,就是匹配模式

action:在找到匹配內容時所執行的一系列命令

 

2.選項參數說明

選項參數 功能
-F 指定輸入文件拆分分隔符
-v 賦值一個用戶定義變數

 

 3.示例

(1)數據準備

[root@yifcloud workspace]# cp /etc/passwd ./

[root@yifcloud workspace]# cat passwd 
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin
adm:x:3:4:adm:/var/adm:/sbin/nologin
lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
sync:x:5:0:sync:/sbin:/bin/sync
shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown
halt:x:7:0:halt:/sbin:/sbin/halt
mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
operator:x:11:0:operator:/root:/sbin/nologin
games:x:12:100:games:/usr/games:/sbin/nologin
ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin
nobody:x:99:99:Nobody:/:/sbin/nologin
systemd-network:x:192:192:systemd Network Management:/:/sbin/nologin
dbus:x:81:81:System message bus:/:/sbin/nologin
polkitd:x:999:998:User for polkitd:/:/sbin/nologin
libstoragemgmt:x:998:997:daemon account for libstoragemgmt:/var/run/lsm:/sbin/nologin
rpc:x:32:32:Rpcbind Daemon:/var/lib/rpcbind:/sbin/nologin
ntp:x:38:38::/etc/ntp:/sbin/nologin
abrt:x:173:173::/etc/abrt:/sbin/nologin
sshd:x:74:74:Privilege-separated SSH:/var/empty/sshd:/sbin/nologin
postfix:x:89:89::/var/spool/postfix:/sbin/nologin
chrony:x:997:995::/var/lib/chrony:/sbin/nologin
tcpdump:x:72:72::/:/sbin/nologin
syslog:x:996:994::/home/syslog:/bin/false
rabbitmq:x:995:991:RabbitMQ messaging server:/var/lib/rabbitmq:/sbin/nologin

 

(2)搜索passwd文件以root關鍵字開頭的所有行,並輸出該行的第7列

[root@yifcloud workspace]# awk -F : '/^root/ {print $7}' passwd 
/bin/bash

 

(3)搜索passwd文件以root關鍵字開頭的所有行,並輸出該行的第1列和第7列,中間以「,」號分隔

[root@yifcloud workspace]# awk -F : '/^root/ {print $1","$7}' passwd 
root,/bin/bash

注意:只有匹配了pattern的行才會執行action

 

(4)只顯示/etc/passwd的第一列和第七列,以逗號分割,且在所有行前面添加列名”user,shell”在最後一行添加「dahaige, /bin/zuishuai」

[root@yifcloud workspace]# awk -F : 'BEGIN{print "user,shell"} {print $1","$7} END{print "dahaige, /bin/zuishuai"}' passwd 

注意:BEGIN在所有數據讀取行之前執行;END在所有數據執行之後執行。

 

(5)將passwd文件中的用戶id增加數值1並輸出

[root@yifcloud workspace]# awk -F : -v i=1 '{print $3 + i}' passwd 

注意:這裡不是$i取值

 

4.awk的內置變數

 

變數 說明
FILENAME 文件名
NR 已讀的記錄數(行數)
NF 瀏覽記錄的域的個數(切割後,列的個數)

 

 5.示例

(1)統計passwd文件名,每行的行號,每行的列數

[root@yifcloud workspace]# awk -F: '{print "filename:"FILENAME ",linenumber:" NR ",columns:" NF}' passwd 
filename:passwd,linenumber:1,columns:7
filename:passwd,linenumber:2,columns:7
filename:passwd,linenumber:3,columns:7
filename:passwd,linenumber:4,columns:7
filename:passwd,linenumber:5,columns:7
filename:passwd,linenumber:6,columns:7
filename:passwd,linenumber:7,columns:7
filename:passwd,linenumber:8,columns:7
filename:passwd,linenumber:9,columns:7
filename:passwd,linenumber:10,columns:7
filename:passwd,linenumber:11,columns:7
filename:passwd,linenumber:12,columns:7
filename:passwd,linenumber:13,columns:7
filename:passwd,linenumber:14,columns:7
filename:passwd,linenumber:15,columns:7
......

 

(2)切割IP

[root@yifcloud workspace]# ifconfig eth0|grep -m1 [^\s]inet|awk -F " " '{print $2}'
172.27.0.2

 

(3)查詢sed.txt中空行所在的行號

[root@yifcloud workspace]# cat sed.txt 
dong shen
guan zhen
wo  wo
lai  lai
        
le  le
[root@yifcloud workspace]# awk '/^\s*$/ {print NR}' sed.txt 
5

注意:awk 中”正則不可以直接寫,需要使用/正則表達式/

 

9.4.sort

sort命令是在Linux里非常有用,它將文件進行排序,並將排序結果標準輸出。

1.基本語法

sort(選項)(參數) 排序的文件名

選項 說明
-n 依照數值的大小排序
-r 以相反的順序來排序
-t 設置排序時所用的分隔字元
-k 指定需要排序的列

 

 示例:

準備sort.sh數據:

[root@yifcloud workspace]# vim sort.sh 

bb:40:5.4
bd:20:4.2
xz:50:2.3
cls:10:3.5
ss:30:1.6

#將以上數據按照分隔符':'分隔,並指定第二列大小反序排序
[root@yifcloud workspace]# sort -t ':' -nr -k 2 sort.sh 
xz:50:2.3
bb:40:5.4
ss:30:1.6
bd:20:4.2
cls:10:3.5

 

更多Shell編程知識在線學習請移步至:

《鳥哥的Linux私房菜》—— 第十一章.認識與學習BASH