日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 运维知识 > linux >内容正文

linux

linux基础-3

發(fā)布時間:2023/12/20 linux 28 豆豆
生活随笔 收集整理的這篇文章主要介紹了 linux基础-3 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

| 管道相關(guān)命令

目標

  • cut
  • sort
  • wc
  • uniq
  • tee
  • tr
  • split
  • awk
  • sed
  • grep
  • 準備數(shù)據(jù)

    zhangsan 68 99 26 lisi 98 66 96 wangwu 38 33 86 zhaoliu 78 44 36 maq 88 22 66 zhouba 98 44 46
  • 以上是成績表信息

  • 使用 逗號 分割, 第一列 是 姓名, 第二列是 語文成績, 第三列是 數(shù)學(xué)成績, 第四列是 英語成績

  • 需求1: 按照 數(shù)學(xué)成績排名, 取出前三名

  • 需求2: 顯示 學(xué)生的數(shù)學(xué)成績

  • 需求3: 顯示 數(shù)學(xué)平均分

  • 需求4: 如何將大文件 切割成 若干小文件

  • 準備工作

    cd /export/ && rm -rf * vim 1.txt 111:aaa:bbb:ccc 222:ddd:eee:fff 333:ggg:hhh 444:iii

1 cut

1.1 目標

  • cut 根據(jù)條件 從命令結(jié)果中 提取 對應(yīng)內(nèi)容

1.2 路徑

  • 第一步: 截取出1.txt文件中前2行的第5個字符
  • 第二步: 截取出1.txt文件中前2行以”:”進行分割的第1,2,3段內(nèi)容(方式二)

1.3 實現(xiàn)

第一步: 截取出1.txt文件中前2行的第5個字符

命令含義
cut 動作 文件從指定文件 截取內(nèi)容
  • 參數(shù)
參數(shù)英文含義
-ccharacters按字符選取內(nèi)容

答案:

head -2 1.txt | cut -c 5 [root@node01 export]# cut -c 5 1.txt a d g i[root@node01 export]# cat 1.txt 111:aaa:bbb:ccc 222:ddd:eee:fff 333:ggg:hhh 444:iii[root@node01 export]# cat 1.txt | cut -c 5 a d g i[root@node01 export]# head -2 1.txt 111:aaa:bbb:ccc 222:ddd:eee:fff[root@node01 export]# head -2 1.txt | cut -c 5 a d

第二步: 截取出1.txt文件中前2行以”:”進行分割的第1,2,3段內(nèi)容

參數(shù)英文含義
-d '分隔符'delimiter指定分隔符
-f n1,n2fields分割以后顯示第幾段內(nèi)容, 使用 , 分割

范圍控制

范圍含義
n只顯示第n項
n-顯示 從第n項 一直到行尾
n-m顯示 從第n項 到 第m項(包括m)

答案:

head -2 1.txt | cut -d ':' -f 1,2,3

或者

head -2 1.txt | cut -d ':' -f 1-3

1.3 小結(jié)

  • 通過 cut 動作 目標文件 可以根據(jù)條件 提取對應(yīng)內(nèi)容

2 sort 的 工作原理

2.1 目標

  • sort可針對文本文件的內(nèi)容,以行為單位來排序。

2.2 路徑

  • 第一步: 對字符串排序
  • 第二步: 去重排序
  • 第三步: 對數(shù)值排序
  • 第四步: 對成績排序

2.3 實現(xiàn)

第一步: 對字符串排序

  • 準備工作
cd /export vim 2.txtbanana apple pear orange pear [root@node01 export]# cat 2.txt banana apple pear orange pear [root@node01 export]# sort 2.txt apple banana orange pear pear [root@node01 export]# cat 2.txt | sort apple banana orange pear pear

第二步: 去重排序

參數(shù)英文含義
-uunique去掉重復(fù)的

它的作用很簡單,就是在輸出行中去除重復(fù)行。

[root@node01 export]# cat 2.txt banana apple pear orange pear [root@node01 export]# sort 2.txt apple banana orange pear pear You have new mail in /var/spool/mail/root [root@node01 export]# sort -u 2.txt apple banana orange pear [root@node01 export]# cat 2.txt | sort -u apple banana orange pear

第三步: 對數(shù)值排序

參數(shù)英文含義
-nnumeric-sort按照數(shù)值大小排序
-rreverse使次序顛倒
  • 準備數(shù)據(jù)

    cd /export/ vim 3.txt 1 3 5 7 11 2 4 6 10 8 9
  • 默認按照字符串排序

    [root@node01 export]# sort 3.txt 1 10 11 2 3 4 5 6 7 8 9 [root@node01 export]# cat 3.txt | sort 1 10 11 2 3 4 5 6 7 8 9
  • 升序

    [root@node01 export]# sort -n 3.txt 1 2 3 4 5 6 7 8 9 10 11 [root@node01 export]# cat 3.txt | sort -n 1 2 3 4 5 6 7 8 9 10 11
  • 倒序

    [root@node01 export]# cat 3.txt | sort -n -r 11 10 9 8 7 6 5 4 3 2 1
  • 合并式

    [root@node01 export]# cat 3.txt | sort -nr 11 10 9 8 7 6 5 4 3 2 1

第四步: 對成績排序

參數(shù)英文含義
-tfield-separator指定字段分隔符
-kkey根據(jù)那一列排序
  • 準備工作

    cd /export vim 4.txt zhangsan 68 99 26 lisi 98 66 96 wangwu 38 33 86 zhaoliu 78 44 36 maqi 88 22 66 zhouba 98 44 46
  • 練習(xí): 根據(jù)第二段成績 進行倒序顯示 所有內(nèi)容

    [root@node01 export]# cat 4.txt zhangsan 68 99 26 lisi 98 66 96 wangwu 38 33 86 zhaoliu 78 44 36 maqi 88 22 66 zhouba 98 44 46 [root@node01 export]# cat 4.txt | sort -t ' ' -k 2 wangwu 38 33 86 zhangsan 68 99 26 zhaoliu 78 44 36 maqi 88 22 66 zhouba 98 44 46 lisi 98 66 96 [root@node01 export]# cat 4.txt | sort -t ' ' -k 2 -n -r zhouba 98 44 46 lisi 98 66 96 maqi 88 22 66 zhaoliu 78 44 36 zhangsan 68 99 26 wangwu 38 33 86

2.4 小結(jié)

  • 通過 sort 選項 文件 可以對文件內(nèi)容進行排序

3 wc命令

3.1 目標

  • 顯示指定文件 字節(jié)數(shù), 單詞數(shù), 行數(shù) 信息.

3.2 路徑

  • 第一步: 顯示指定文件 字節(jié)數(shù), 單詞數(shù), 行數(shù) 信息.
  • 第二步: 只顯示 文件 的行數(shù)
  • 第三步: 統(tǒng)計多個文件的 行數(shù) 單詞數(shù) 字節(jié)數(shù)
  • 第四步: 查看 /etc 目錄下 有多少個 子內(nèi)容

3.3 實現(xiàn)

第一步: 顯示指定文件 字節(jié)數(shù), 單詞數(shù), 行數(shù) 信息.

命令含義
wc 文件名顯示指定文件 字節(jié)數(shù), 單詞數(shù), 行數(shù) 信息
  • 準備工作

    cd /export/ vim 5.txt 111 222 bbb 333 aaa bbb 444 aaa bbb ccc 555 aaa bbb ccc ddd 666 aaa bbb ccc ddd eee
  • 練習(xí): 顯示指定文件 字節(jié)數(shù), 單詞數(shù), 行數(shù) 信息.

[root@node01 export]# wc 5.txt 6 21 85 5.txt [root@node01 export]# cat 5.txt 111 222 bbb 333 aaa bbb 444 aaa bbb ccc 555 aaa bbb ccc ddd 666 aaa bbb ccc ddd eee [root@node01 export]# cat 5.txt | wc6 21 85

第二步: 只顯示 文件 的行數(shù)

參數(shù)英文含義
-cbytes字節(jié)數(shù)
-wwords單詞數(shù)
-llines行數(shù)
[root@node01 export]# cat 5.txt 111 222 bbb 333 aaa bbb 444 aaa bbb ccc 555 aaa bbb ccc ddd 666 aaa bbb ccc ddd eee You have new mail in /var/spool/mail/root [root@node01 export]# cat 5.txt | wc6 21 85 [root@node01 export]# cat 5.txt | wc -l 6

第三步: 統(tǒng)計多個文件的 行數(shù) 單詞數(shù) 字節(jié)數(shù)

[root@node01 export]# wc 2.txt 3.txt 4.txt 5.txt 5 5 30 2.txt11 11 24 3.txt6 24 94 4.txt6 21 85 5.txt28 61 233 total [root@node01 export]# wc *.txt5 5 30 2.txt11 11 24 3.txt6 24 94 4.txt6 21 85 5.txt28 61 233 total

第四步: 查看 /etc 目錄下 有多少個 子內(nèi)容

ll /etc | wc -l

3.4 小結(jié)

  • 通過 wc 文件 就可以 統(tǒng)計 文件的 字節(jié)數(shù)、單詞數(shù)、行數(shù).

4 uniq

uniq 命令用于檢查及刪除文本文件中重復(fù)出現(xiàn)的行,一般與 sort 命令結(jié)合使用。

4.1 目標

  • uniq 命令用于檢查及刪除文本文件中重復(fù)出現(xiàn)的行,一般與 sort 命令結(jié)合使用。

4.2路徑

  • 第一步:實現(xiàn)去重效果
  • 第二步:不但去重,還要 統(tǒng)計出現(xiàn)的次數(shù)

4.3 實現(xiàn)

第一步:實現(xiàn)去重效果

命令英文含義
uniq [參數(shù)] 文件unique 唯一去除重復(fù)行
  • 準備工作

    cd /export/ vim 6.txt 張三 98 李四 100 王五 90 趙六 95 麻七 70 李四 100 王五 90 趙六 95 麻七 70
  • 需求: 實現(xiàn)去重效果

    ?

  • [root@node01 export]# cat 6.txt 張三 98 李四 100 王五 90 趙六 95 麻七 70 李四 100 王五 90 趙六 95 麻七 70 [root@node01 export]# cat 6.txt | sort 張三 98 李四 100 李四 100 王五 90 王五 90 趙六 95 趙六 95 麻七 70 麻七 70 [root@node01 export]# cat 6.txt | sort | uniq 張三 98 李四 100 王五 90 趙六 95 麻七 70

第二步:不但去重,還要 統(tǒng)計出現(xiàn)的次數(shù)

參數(shù)英文含義
-ccount統(tǒng)計每行內(nèi)容出現(xiàn)的次數(shù)
[root@node01 export]# cat 6.txt | sort | uniq -c1 張三 982 李四 1002 王五 902 趙六 952 麻七 70

4.4 小結(jié)

  • 通過 uniq [選項] 文件 就可以完成 去重行 和 統(tǒng)計次數(shù)

5 tee

5.1 目標

  • 通過 tee 可以將命令結(jié)果 通過管道 輸出到 多個文件

5.2 實現(xiàn)

命令含義
命令結(jié)果 | tee 文件1 文件2 文件3通過 tee 可以將命令結(jié)果 通過管道 輸出到 多個文件
  • 將去重統(tǒng)計的結(jié)果 放到 a.txt、b.txt、c.txt 文件中

    [root@node01 export]# ls 2.txt 3.txt 4.txt 5.txt 6.txt [root@node01 export]# cat 6.txt | sort | uniq -c | tee a.txt b.txt c.txt1 張三 982 李四 1002 王五 902 趙六 952 麻七 70 [root@node01 export]# ls 2.txt 3.txt 4.txt 5.txt 6.txt a.txt b.txt c.txt [root@node01 export]# cat a.txt 1 張三 982 李四 1002 王五 902 趙六 952 麻七 70

5.3 小結(jié)

  • 通過 tee 可以將命令結(jié)果 通過管道 輸出到 多個文件

6 tr

6.1 目標

  • 通過 tr 命令用于 替換刪除 文件中的字符。

6.2 路徑

  • 第一步: 實現(xiàn) 替換 效果
  • 第二步: 實現(xiàn) 刪除 效果
  • 第三步: 完成 單詞計數(shù) 案例

6.3 實現(xiàn)

第一步: 實現(xiàn) 替換效果

命令英文含義
命令結(jié)果 | tr 被替換的字符 新字符translate實現(xiàn) 替換效果
  • 準備工作

    cd /export vim 7.txt itheima HELLO abc1d4e5f
  • 需求:

    # 將 小寫i 替換成 大寫 I # 把 小寫 的轉(zhuǎn)換為大寫 # 把 大寫 轉(zhuǎn)成 小寫
[root@node01 export]# cat 7.txt itheima HELLO abc1d4e5f [root@node01 export]# cat 7.txt | tr 'i' 'I' ItheIma HELLO abc1d4e5f [root@node01 export]# cat 7.txt | tr [a-z] [A-Z] ITHEIMA HELLO ABC1D4E5F You have new mail in /var/spool/mail/root [root@node01 export]# cat 7.txt | tr [A-Z] [a-z] itheima hello abc1d4e5f

第二步: 實現(xiàn)刪除效果

命令英文含義
命令結(jié)果 | tr -d 被刪除的字符delete刪除指定的字符
  • 需求: 刪除abc1d4e5f中的數(shù)字
echo 'abc1d4e5f' | tr -d [0-9]

第三步: 單詞計數(shù)

  • 準備工作

    cd /export vim 8.txt hello,world,hadoop hive,sqoop,flume,hello kitty,tom,jerry,world hadoop

    分析:

    1 將, 換成 換行2 排序3 去重4 計數(shù) -------- 查看文件內(nèi)容 [root@node01 export]# cat 8.txt hello,world,hadoop hive,sqoop,flume,hello kitty,tom,jerry,world hadoop-------- 將 逗號, 替換成 換行符 [root@node01 export]# cat 8.txt | tr ',' '\n' hello world hadoop hive sqoop flume hello kitty tom jerry world hadoop-------- 排序 [root@node01 export]# cat 8.txt | tr ',' '\n' | sort flume hadoop hadoop hello hello hive jerry kitty sqoop tom world world-------- 去重 [root@node01 export]# cat 8.txt | tr ',' '\n' | sort | uniq flume hadoop hello hive jerry kitty sqoop tom world-------- 計數(shù) [root@node01 export]# cat 8.txt | tr ',' '\n' | sort | uniq -c1 flume2 hadoop2 hello1 hive1 jerry1 kitty1 sqoop1 tom2 world [root@node01 export]#

6.4 小結(jié)

  • 通過 tr [選項] 字符1 字符2 可以 實現(xiàn) 替換刪除 效果

  • 準備工作

    # 清空目錄內(nèi)容 cd /export/ && rm -rf *# 查看 /etc目錄下 以.conf以結(jié)尾的文件的內(nèi)容 cat -n /etc/*.conf# 將命令結(jié)果 追加到 /export/v.txt 文件中 cat -n /etc/*.conf >> /export/v.txt# 查看文件內(nèi)容 ls# 查看新文件的行數(shù) wc -l v.txt

7 split

7.1 目標

  • 通過 split 命令將大文件 切分成 若干小文件

7.2 路徑

  • 第一步: 按 字節(jié) 將 大文件 切分成 若干小文件
  • 第二步: 按 行數(shù) 將 大文件 切分成 若干小文件

7.3 實現(xiàn)

第一步: 按 字節(jié) 將 大文件 切分成 若干小文件

命令英文含義
split -b 10k 文件byte將大文件切分成若干10KB的小文件
[root@node01 export]# ll -h total 108K -rw-r--r-- 1 root root 105K Jul 12 20:35 v.txt [root@node01 export]# split -b 20k v.txt [root@node01 export]# ll total 216 -rw-r--r-- 1 root root 106538 Jul 12 20:35 v.txt -rw-r--r-- 1 root root 20480 Jul 12 20:39 xaa -rw-r--r-- 1 root root 20480 Jul 12 20:39 xab -rw-r--r-- 1 root root 20480 Jul 12 20:39 xac -rw-r--r-- 1 root root 20480 Jul 12 20:39 xad -rw-r--r-- 1 root root 20480 Jul 12 20:39 xae -rw-r--r-- 1 root root 4138 Jul 12 20:39 xaf

第二步: 按 行數(shù) 將 大文件 切分成 若干小文件

命令英文含義
split -l 1000 文件lines將大文件切分成若干1000行 的小文件
# 清空不用的內(nèi)容 [root@node01 export]# rm -rf x*# 羅列當(dāng)前目錄中內(nèi)容 [root@node01 export]# ls v.txt# 查看指定文件的行數(shù): 共 2780行 [root@node01 export]# wc -l v.txt 2780 v.txt# 按照行數(shù) 每個文件1000行 進行切割 [root@node01 export]# split -l 1000 v.txt # 查看當(dāng)前文件下每個文件的行數(shù) [root@node01 export]# wc -l *2780 v.txt1000 xaa1000 xab780 xac

7.4 小結(jié)

  • 通過 split 選項 文件名 命令將大文件 切分成 若干小文件

  • 準備工作1:

    # 清空指定目錄內(nèi)容 cd /export && rm -rf *# 新建文件 vim score.txt zhangsan 68 99 26 lisi 98 66 96 wangwu 38 33 86 zhaoliu 78 44 36 maq 88 22 66 zhouba 98 44 46

8 awk(重點重點重點)

8.1 目標

  • 通過 awk 實現(xiàn) 模糊查詢, 按需提取字段, 還可以進行 判斷 和 簡單的運算等.

8.2 步驟

  • 第一步: 模糊查詢

  • 第二步: 指定分割符, 根據(jù)下標顯示內(nèi)容

  • 第三步: 指定輸出字段的分割符

  • 第四步: 調(diào)用 awk 提供的函數(shù)

  • 第五步: 通過if語句判斷$4是否及格

  • 第六步: 段內(nèi)容 求和

8.3 實現(xiàn)

第一步: 搜索含有 zhang 和 li 的學(xué)生成績

命令含義
awk ‘/搜索字符/’ score.txt模糊查詢
# 查看文檔內(nèi)容 [root@node01 export]# cat score.txt zhangsan 68 99 26 lisi 98 66 96 wangwu 38 33 86 zhaoliu 78 44 36 maq 88 22 66 zhouba 98 44 46# 搜索含有 zhang 和 li 的學(xué)生成績 [root@node01 export]# cat score.txt | awk '/zhang|li/' zhangsan 68 99 26 lisi 98 66 96 zhaoliu 78 44 36

第二步: 指定分割符, 根據(jù)下標顯示內(nèi)容

命令含義
awk -F ‘,’ ‘{print $1, $2, $3}’ 文件操作1.txt文件, 根據(jù) 逗號 分割, 打印 第一段 第二段 第三段 內(nèi)容

選項

選項英文含義
-F ','field-separator使用 指定字符 分割
$ + 數(shù)字獲取第幾段內(nèi)容
$0獲取 當(dāng)前行 內(nèi)容
NFfield表示當(dāng)前行共有多少個字段
$NF代表 最后一個字段
$(NF-1)代表 倒數(shù)第二個字段
NR代表 處理的是第幾行
[root@node01 export]# cat score.txt zhangsan 68 99 26 lisi 98 66 96 wangwu 38 33 86 zhaoliu 78 44 36 maq 88 22 66 zhouba 98 44 46[root@node01 export]# cat score.txt | awk -F ' ' '{print $1,$2,$3}' zhangsan 68 99 lisi 98 66 wangwu 38 33 zhaoliu 78 44 maq 88 22 zhouba 98 44

第三步: 指定分割符, 根據(jù)下標顯示內(nèi)容

命令含義
awk -F ’ ’ ‘{OFS="==="}{print $1, $2, $3}’ 1.txt操作1.txt文件, 根據(jù) 逗號 分割, 打印 第一段 第二段 第三段 內(nèi)容

選項

選項英文含義
OFS="字符"output field separator向外輸出時的段分割字符串
轉(zhuǎn)義序列含義
\b退格
\f換頁
\n換行
\r回車
\t制表符
# 查看文檔內(nèi)容 [root@node01 export]# cat score.txt zhangsan 68 99 26 lisi 98 66 96 wangwu 38 33 86 zhaoliu 78 44 36 maq 88 22 66 zhouba 98 44 46# 按照 === 進行分割, 打印 第一段 第二段 第三段 [root@node01 export]# cat score.txt | awk -F ' ' '{OFS="==="}{print $1,$2,$3}' zhangsan===68===99 lisi===98===66 wangwu===38===33 zhaoliu===78===44 maq===88===22 zhouba===98===44# 按照 制表符tab 進行分割, 打印 第一段 第二段 第三段 [root@node01 export]# cat score.txt | awk -F ' ' '{OFS="\t"}{print $1,$2,$3}' zhangsan 68 99 lisi 98 66 wangwu 38 33 zhaoliu 78 44 maq 88 22 zhouba 98 44

第四步: 調(diào)用 awk 提供的函數(shù)

命令含義
awk -F ‘,’ ‘{print toupper($2)}’ 1.txt操作1.txt文件, 根據(jù) 逗號 分割, 打印 第一段 第二段 第三段 內(nèi)容

常用函數(shù)如下:

函數(shù)名含義作用
toupper()upper字符 轉(zhuǎn)成 大寫
tolower()lower字符 轉(zhuǎn)成小寫
length()length返回 字符長度
[root@node01 export]# cat score.txt zhangsan 68 99 26 lisi 98 66 96 wangwu 38 33 86 zhaoliu 78 44 36 maq 88 22 66 zhouba 98 44 46# 打印第一段內(nèi)容 [root@node01 export]# cat score.txt | awk -F ' ' '{print $1}' zhangsan lisi wangwu zhaoliu maq zhouba# 將第一段內(nèi)容轉(zhuǎn)成大寫 且 顯示 [root@node01 export]# cat score.txt | awk -F ' ' '{print toupper($1)}' ZHANGSAN LISI WANGWU ZHAOLIU MAQ ZHOUBA

第五步: if語句 查詢及格的學(xué)生信息

命令含義
awk -F ‘,’ ‘{if($4>60) print $1, $4 }’ score.txt如果及格,就顯示 $1, $4
awk -F ‘,’ ‘{if($4>60) print $1, $4, “及格”; else print $1, $4, “不及格”}’ score.txt顯示 姓名, $4, 是否及格

選項

參數(shù)含義
if($0 ~ “aa”) print $0如果這一行包含 “aa”, 就打印這一行內(nèi)容
if($1 ~ “aa”) print $0如果**第一段 **包含 “aa”, 就打印這一行內(nèi)容
if($1 == “l(fā)isi”) print $0如果第一段 等于 “l(fā)isi”, 就打印這一行內(nèi)容
[root@node01 export]# cat score.txt zhangsan 68 99 26 lisi 98 66 96 wangwu 38 33 86 zhaoliu 78 44 36 maq 88 22 66 zhouba 98 44 46# 打印及格的同學(xué)信息 [root@node01 export]# cat score.txt | awk -F ' ' '{if($4>60) print $1,$4,"及格"}' lisi 96 及格 wangwu 86 及格 maq 66 及格# 顯示學(xué)生的及格狀態(tài) [root@node01 export]# cat score.txt | awk -F ' ' '{if($4>60) print $1,$4,"及格"; else print $1,$4,"不及格"}' zhangsan 26 不及格 lisi 96 及格 wangwu 86 及格 zhaoliu 36 不及格 maq 66 及格 zhouba 46 不及格

第六步: 段內(nèi)容 求指定學(xué)科平均分

命令含義
awk ‘BEGIN{初始化操作}{每行都執(zhí)行} END{結(jié)束時操作}’ 文件名BEGIN{ 這里面放的是執(zhí)行前的語句 }
{這里面放的是處理每一行時要執(zhí)行的語句}
END {這里面放的是處理完所有的行后要執(zhí)行的語句 }
# 查看文檔內(nèi)容 [root@node01 export]# cat score.txt zhangsan 68 99 26 lisi 98 66 96 wangwu 38 33 86 zhaoliu 78 44 36 maq 88 22 66 zhouba 98 44 46# 查看總分 [root@node01 export]# cat score.txt | awk -F ' ' 'BEGIN{}{total=total+$4} END{print total}' 356# 查看總分, 總?cè)藬?shù) [root@node01 export]# cat score.txt | awk -F ' ' 'BEGIN{}{total=total+$4} END{print total, NR}' 356 6# 查看總分, 總?cè)藬?shù), 平均分 [root@node01 export]# cat score.txt | awk -F ' ' 'BEGIN{}{total=total+$4} END{print total, NR, (total/NR)}' 356 6 59.3333

8.4 小結(jié)

  • 通過 awk 動作 文件名 更加靈活的解析文件.

  • 準備工作

    cd /export | rm -rf * vim 1.txt aaa java root bbb hello ccc rt ddd root nologin eee rtt fff ROOT nologin ggg rttt

9 sed

9.1 目標

  • 通過 sed 可以實現(xiàn) 過濾替換 的功能.

9.2 路徑

  • 第一步: 實現(xiàn) 查詢 功能
  • 第二步: 實現(xiàn) 刪除 功能
  • 第三步: 實現(xiàn) 修改 功能
  • 第四步: 實現(xiàn) 替換 功能
  • 第五步: 對 原文件 進行操作
  • 第六步: 綜合 練習(xí)

9.3 實現(xiàn)

第一步: 實現(xiàn) 查詢 功能

命令含義
sed 可選項 目標文件對目標文件 進行 過濾查詢替換

可選參數(shù)

可選項英文含義
pprint打印
$代表 最后一行
-n僅顯示處理后的結(jié)果
-eexpression根據(jù)表達式 進行處理
  • 練習(xí)1 列出 1.txt的 3~5行 的數(shù)據(jù)

# 查看所有內(nèi)容 [root@node01 export]# cat 1.txt aaa java root bbb hello ccc rt ddd root nologin eee rtt fff ROOT nologin ggg rttt# 查看前3~5行內(nèi)容 [root@node01 export]# cat 1.txt | sed -n -e '3,5p' ccc rt ddd root nologin eee rtt
  • 練習(xí)2 列出01.txt的所有數(shù)據(jù)

# 查看文件所有內(nèi)容 [root@node01 export]# cat 1.txt aaa java root bbb hello ccc rt ddd root nologin eee rtt fff ROOT nologin ggg rttt# 查看文件所有內(nèi)容, $代表最后一行 [root@node01 export]# cat 1.txt | sed -n -e '1,$p' aaa java root bbb hello ccc rt ddd root nologin eee rtt fff ROOT nologin ggg rttt
  • 練習(xí)3 列出01.txt的3-5行數(shù)據(jù) 且 顯示行號

可選項含義
=打印當(dāng)前行號
[root@node01 export]# sed -n -e '3,5=' -e '3,5p' 1.txt 3 ccc rt 4 ddd root nologin 5 eee rtt[root@node01 export]# cat 1.txt aaa java root bbb hello ccc rt ddd root nologin eee rtt fff ROOT nologin ggg rttt[root@node01 export]# cat -n 1.txt 1 aaa java root2 bbb hello3 ccc rt4 ddd root nologin5 eee rtt6 fff ROOT nologin7 ggg rttt[root@node01 export]# cat -n 1.txt | sed -n -e '3,5p'3 ccc rt4 ddd root nologin5 eee rtt
  • 練習(xí)4: 查找 1.txt 中包含 root 行

答案:

[root@node01 export]# cat 1.txt aaa java root bbb hello ccc rt ddd root nologin eee rtt fff ROOT nologin ggg rttt[root@node01 export]# cat 1.txt | sed -n -e '/root/p' aaa java root ddd root nologin[root@node01 export]# cat 1.txt | grep root aaa java root ddd root nologin
  • 練習(xí)5 列出01.txt中包含root的內(nèi)容,root不區(qū)分大小寫,并顯示行號

可選項英文含義
Iignore忽略大小寫

答案:

[root@node01 export]# cat -n 1.txt | sed -n -e '/root/Ip'1 aaa java root4 ddd root nologin6 fff ROOT nologin[root@node01 export]# cat -n 1.txt | grep -i root1 aaa java root4 ddd root nologin6 fff ROOT nologin
  • 練習(xí)6 查找出1.txt中 字母r后面是多個t的行,并顯示行號

可選項英文含義
-rregexp-extended識別正則

答案:

# 顯示所有 且 顯示行號 [root@node01 export]# cat -n 1.txt 1 aaa java root2 bbb hello3 ccc rt4 ddd root nologin5 eee rtt6 fff ROOT nologin7 ggg rttt# 搜索匹配的行 [root@node01 export]# cat -n 1.txt | sed -n -r -e '/r+t/p'3 ccc rt5 eee rtt7 ggg rttt

第二步: 實現(xiàn) 刪除 功能

  • 練習(xí)1 刪除01.txt中前3行數(shù)據(jù),并顯示行號

可選項英文含義
ddelete刪除指定內(nèi)容

答案:

# 打印所有內(nèi)容 且 顯示行號 [root@node01 export]# nl 1.txt 1 aaa java root2 bbb hello3 ccc rt4 ddd root nologin5 eee rtt6 fff ROOT nologin7 ggg rttt[root@node01 export]# nl 1.txt | sed -e '1,3d'4 ddd root nologin5 eee rtt6 fff ROOT nologin7 ggg rttt
  • 練習(xí)2 保留1.txt中前3行數(shù)據(jù),并顯示行號

答案:

[root@node01 export]# nl 1.txt | sed -e '4,$d'1 aaa java root2 bbb hello3 ccc rt# 顯示前三行內(nèi)容 [root@node01 export]# head -3 1.txt aaa java root bbb hello ccc rt# 顯示前三行內(nèi)容 且?guī)?序號 [root@node01 export]# head -3 1.txt | nl1 aaa java root2 bbb hello3 ccc rt# 顯示所有 [root@node01 export]# nl 1.txt 1 aaa java root2 bbb hello3 ccc rt4 ddd root nologin5 eee rtt6 fff ROOT nologin7 ggg rttt# 顯示前三行內(nèi)容 且?guī)?序號 [root@node01 export]# nl 1.txt | head -31 aaa java root2 bbb hello3 ccc rt

第三步: 實現(xiàn) 修改 功能

  • 練習(xí)1: 在01.txt的第二行 下面 添加aaaaa,并顯示行號

參數(shù)英文含義
iinsert目標前面 插入內(nèi)容
aappend目標后面 追加內(nèi)容

答案:

[root@node01 export]# nl 1.txt 1 aaa java root2 bbb hello3 ccc rt4 ddd root nologin5 eee rtt6 fff ROOT nologin7 ggg rttt[root@node01 export]# nl 1.txt | sed -e '2a aaaaaa'1 aaa java root2 bbb hello aaaaaa3 ccc rt4 ddd root nologin5 eee rtt6 fff ROOT nologin7 ggg rttt
  • 練習(xí)2 在1.txt的第1行前添加bbbbb,并顯示行號

答案:

[root@node01 export]# nl 1.txt 1 aaa java root2 bbb hello3 ccc rt4 ddd root nologin5 eee rtt6 fff ROOT nologin7 ggg rttt[root@node01 export]# nl 1.txt | sed -e '1i bbbbbbbbb' bbbbbbbbb1 aaa java root2 bbb hello3 ccc rt4 ddd root nologin5 eee rtt6 fff ROOT nologin7 ggg rttt

第四步: 實現(xiàn) 替換 功能

  • 練習(xí)1 把1.txt中的nologin替換成為huawei,并顯示行號

英文含義
s/oldString/newString/replace替換

答案:

[root@node01 export]# nl 1.txt 1 aaa java root2 bbb hello3 ccc rt4 ddd root nologin5 eee rtt6 fff ROOT nologin7 ggg rttt[root@node01 export]# nl 1.txt | sed -e 's/root/huawei/'1 aaa java huawei2 bbb hello3 ccc rt4 ddd huawei nologin5 eee rtt6 fff ROOT nologin7 ggg rttt
  • 練習(xí)2 把01.txt中的1,2行替換為aaa,并顯示行號

選項英文
2c 新字符串replace使用新字符串 替換 選中的行

答案:

[root@node01 export]# nl 1.txt 1 aaa java root2 bbb hello3 ccc rt4 ddd root nologin5 eee rtt6 fff ROOT nologin7 ggg rttt[root@node01 export]# nl 1.txt | sed -e '2c aaaa'1 aaa java root aaaa3 ccc rt4 ddd root nologin5 eee rtt6 fff ROOT nologin7 ggg rttt

第五步: 對 原文件 進行操作

  • 練習(xí)1 在01.txt中把nologin替換為 huawei

參數(shù)英文含義
-iin-place替換原有文件內(nèi)容

答案:

# 備份原始文件內(nèi)容 cp 1.txt 2.txt# 原文件內(nèi)容 [root@node01 export]# cat 1.txt aaa java root bbb hello ccc rt ddd root nologin eee rtt fff ROOT nologin ggg rttt# 替換 [root@node01 export]# sed -i -e 's/nologin/huawei/' 1.txt # 觀察變化 [root@node01 export]# cat 1.txt aaa java root bbb hello ccc rt ddd root huawei eee rtt fff ROOT huawei ggg rttt
  • 練習(xí)2 在01.txt文件中第2、3行替換為aaaaaa

答案:

# 原文件內(nèi)容 [root@node01 export]# cat 1.txt aaa java root bbb hello ccc rt ddd root huawei eee rtt fff ROOT huawei ggg rttt# 替換 [root@node01 export]# sed -i -e '2,3c aaaaaaa' 1.txt # 觀察變化 [root@node01 export]# cat 1.txt aaa java root aaaaaaa ddd root huawei eee rtt fff ROOT huawei ggg rttt

注意:在進行操作之前,最好是對數(shù)據(jù)進行備份,放置操作失誤,數(shù)據(jù)無法恢復(fù)!

  • 練習(xí)3 刪除01.txt中前2行數(shù)據(jù),并且刪除原文件中的數(shù)據(jù)

答案:

# 查看原文件內(nèi)容 [root@node01 export]# cat 2.txt aaa java root aaaaaaa ddd root huawei eee rtt fff ROOT huawei ggg rttt# 刪除1,2行內(nèi)容 [root@node01 export]# sed -i -e '1,2d' 2.txt # 查看原文件內(nèi)容 [root@node01 export]# cat 2.txt ddd root huawei eee rtt fff ROOT huawei ggg rttt

第六步: 綜合 練習(xí)

  • 練習(xí)1 獲取ip地址

符號含義
^表示開始^aaa 表示以 aaa 開始
$表示結(jié)尾bbb$ 表示以 bbb 結(jié)尾
.*表示任意^.* 表示以 任意字符開始

答案:

# 查看網(wǎng)卡信息 [root@node01 export]# ifconfig eth0 eth0 Link encap:Ethernet HWaddr 00:0C:29:DF:0A:6A inet addr:192.168.100.204 Bcast:192.168.100.255 Mask:255.255.255.0inet6 addr: fe80::20c:29ff:fedf:a6a/64 Scope:LinkUP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1RX packets:12999 errors:0 dropped:0 overruns:0 frame:0TX packets:7353 errors:0 dropped:0 overruns:0 carrier:0collisions:0 txqueuelen:1000 RX bytes:1334125 (1.2 MiB) TX bytes:1333707 (1.2 MiB)# 根據(jù)關(guān)鍵 搜索行 [root@node01 export]# ifconfig eth0 | grep 'inet addr:'inet addr:192.168.100.204 Bcast:192.168.100.255 Mask:255.255.255.0# 去掉ip地址以前的部分 [root@node01 export]# ifconfig eth0 | grep 'inet addr:' | sed -e 's/^.*addr://' 192.168.100.204 Bcast:192.168.100.255 Mask:255.255.255.0# 去掉ip地址以后的部分 [root@node01 export]# ifconfig eth0 | grep 'inet addr:' | sed -e 's/^.*addr://' | sed -e 's/Bcast:.*$//' 192.168.100.204
  • 練習(xí)2 從 2.txt 中提出數(shù)據(jù),匹配出包含root的內(nèi)容,再把nologin替換為itheima

答案:

[root@node01 export]# nl 2.txt 1 aaa java root2 bbb hello3 ccc rt4 ddd root nologin5 eee rtt6 fff ROOT nologin7 ggg rttt# 匹配含有root內(nèi)容的行 [root@node01 export]# nl 2.txt | grep root1 aaa java root4 ddd root nologin# 匹配含有root內(nèi)容的行 且 忽略大小寫 [root@node01 export]# nl 2.txt | grep -i root1 aaa java root4 ddd root nologin6 fff ROOT nologin# 將nologin 替換成 itheima [root@node01 export]# nl 2.txt | grep -i root | sed -e 's/nologin/itheima/' 1 aaa java root4 ddd root itheima6 fff ROOT itheima nl 01.txt | grep 'root' | sed -e 's/nologin/itheima/'或者nl 01.txt | sed -n -e '/root/p' | sed -e 's/nologin/itheima/'或者nl 01.txt | sed -n -e '/root/{s/nologin/itheima/p}' #只顯示替換內(nèi)容的行
  • 練習(xí)3 從2.txt中提出數(shù)據(jù),刪除前2行,并把nologin替換為itheima,并顯示行號

答案:

[root@node01 export]# nl 2.txt 1 aaa java root2 bbb hello3 ccc rt4 ddd root nologin5 eee rtt6 fff ROOT nologin7 ggg rttt# 刪除前兩行內(nèi)容 [root@node01 export]# nl 2.txt | sed -e '1,2d'3 ccc rt4 ddd root nologin5 eee rtt6 fff ROOT nologin7 ggg rttt# 替換內(nèi)容 [root@node01 export]# nl 2.txt | sed -e '1,2d' | sed -e 's/nologin/itheima/'3 ccc rt4 ddd root itheima5 eee rtt6 fff ROOT itheima7 ggg rttt

2. Shell 編程

2.1 簡介

Shell 是一個用 C 語言編寫的程序,通過 Shell 用戶可以訪問操作系統(tǒng)內(nèi)核服務(wù)。

Shell 既是一種命令語言,又是一種程序設(shè)計語言。

Shell script 是一種為 shell 編寫的腳本程序。Shell 編程一般指 shell腳本編程,不是指開發(fā) shell 自身。

Shell 編程跟 java、php 編程一樣,只要有一個能編寫代碼的文本編輯器和一個能解釋執(zhí)行的腳本解釋器就可以了。

Linux 的 Shell 解釋器 種類眾多,一個系統(tǒng)可以存在多個 shell解釋器,可以通過 cat /etc/shells 命令查看系統(tǒng)中安裝的 shell解釋器。

Bash 由于易用和免費,在日常工作中被廣泛使用。同時,Bash 也是大多數(shù)Linux 系統(tǒng)默認的 Shell。

shell 解釋器

java 需要 虛擬機解釋器, 同理 shell腳本也需要 解析器

[root@node04 shells]# cat /etc/shells /bin/sh /bin/bash /sbin/nologin /bin/dash /bin/tcsh /bin/csh

2.2快速入門

1 編寫腳本

新建 /export/01.sh 文件

#!/bin/bashecho 'hello world'

#!是一個約定的標記,它告訴系統(tǒng)這個腳本需要什么解釋器來執(zhí)行,即使用哪一種 Shell。

echo 命令用于向窗口輸出文本。

2 執(zhí)行shell腳本

  • 執(zhí)行方式一

[root@node04 shells]# /bin/sh 01.sh hello world[root@node04 shells]# /bin/bash 01.sh hello world
  • 問題: bash 和 sh 是什么關(guān)系?

sh 是 bash 的 快捷方式

3.2 執(zhí)行方式二

方式一的簡化方式

[root@node04 shells]# bash hello.sh hello world[root@node04 shells]# sh hello.sh hello world

3.2.1 問題: 請思考 為什么可以省略 /bin/

因為 PATH環(huán)境變量中增加了 /bin/目錄, 所以 使用/bin/sh等類似指令時, 可以省略 /bin

3.3 執(zhí)行方式三

./文件名

[root@node04 shells]# ll 總用量 4 -rw-r--r--. 1 root root 32 3月 14 00:20 01.sh[root@node04 shells]# ./01.sh -bash: ./01.sh: 權(quán)限不夠

3.3.1 權(quán)限不夠怎么辦?

[root@node04 shells]# chmod 755 01.sh[root@node04 shells]# ll 總用量 4 -rwxr-xr-x. 1 root root 32 3月 14 00:20 01.sh# 再次執(zhí)行: [root@node04 shells]# ./01.sh hello world!

2.3 shell變量

1 簡介

在shell腳本中, 定義變量時,變量名不加美元符號($),如:

your_name=“runoob.com”

注意 : 變量名和等號之間不能有空格,這可能和你熟悉的所有編程語言都不一樣。

同時,變量名的命名須遵循如下規(guī)則:

  • 命名只能使用英文字母,數(shù)字和下劃線,首個字符不能以數(shù)字開頭。
  • 中間不能有空格,可以使用下劃線(_)。
  • 不能使用標點符號。
  • 不能使用bash里的關(guān)鍵字(可用help命令查看保留關(guān)鍵字)。

有效的 Shell 變量名示例如下:

RUNOOB LD_LIBRARY_PATH _var var2

無效的變量命名:

?var=123 user*name=runoob

除了顯式地直接賦值,還可以用語句給變量賦值,如:

for file in `ls /etc`

for file in $(ls /etc)

以上語句將 /etc 下目錄的文件名循環(huán)出來。

?

2 使用變量

使用一個定義過的變量,只要在變量名前面加美元符號即可,如:

your_name="zhangsan"echo $your_nameecho ${your_name}

變量名外面的花括號是可選的,加不加都行,加花括號是為了幫助解釋器識別變量的邊界,比如下面這種情況:

for skill in java php python; doecho "I am good at ${skill}Script" done

如果不給skill變量加花括號,寫成echo "I am good at skillScript",解釋器就會把skillScript",解釋器就會把skillScript"skillScript當(dāng)成一個變量(其值為空),代碼執(zhí)行結(jié)果就不是我們期望的樣子了。

推薦給所有變量加上花括號,這是個好的編程習(xí)慣。

已定義的變量,可以被重新定義,如:

your_name="tom" echo $your_name your_name="alibaba" echo $your_name

這樣寫是合法的,但注意,第二次賦值的時候不能寫yourname="alibaba",使用變量的時候才加美元符(your_name="alibaba",使用變量的時候才加美元符(yourn?ame="alibaba"使)。

[root@node01 export]# yourname=zhangsan [root@node01 export]# echo $yourname zhangsan [root@node01 export]# echo ${yourname} zhangsan [root@node01 export]# echo "$yourname喜歡吃香蕉" zhangsan喜歡吃香蕉 [root@node01 export]# echo "$yournamelikebanana"[root@node01 export]# echo "${yourname}likebanana" zhangsanlikebanana

3 刪除變量

使用 unset 命令可以刪除變量。語法:

unset variable_name

變量被刪除后不能再次使用。unset 命令不能刪除只讀變量。

實例

#!/bin/sh myUrl="http://www.runoob.com" unset myUrl echo $myUrl

以上實例執(zhí)行將沒有任何輸出。

4 只讀變量

使用 readonly 命令可以將變量定義為只讀變量,只讀變量的值不能被改變。

下面的例子嘗試更改只讀變量,結(jié)果報錯:

#!/bin/bashmyUrl="http://www.google.com" readonly myUrl myUrl="http://www.runoob.com"

運行腳本,結(jié)果如下:

/bin/sh: NAME: This variable is read only.

2.4 字符串

? 字符串是shell編程中最常用最有用的數(shù)據(jù)類型(除了數(shù)字和字符串,也沒啥其它類型好用了),字符串可以用單引號,也可以用雙引號,也可以不用引號。

1 單引號

skill='java'echo '$skill'

輸出結(jié)果為:

$skill

單引號字符串的限制:

  • 單引號里的任何字符都會原樣輸出,單引號字符串中的變量是無效的;
  • 單引號字串中不能出現(xiàn)單獨一個的單引號(對單引號使用轉(zhuǎn)義符后也不行),但可成對出現(xiàn),作為字符串拼接使用。

2 雙引號

skill='java'echo "$skill"

輸出結(jié)果為:

I am goot at java

雙引號的優(yōu)點:

  • 雙引號里可以有變量
  • 雙引號里可以出現(xiàn)轉(zhuǎn)義字符

3 獲取字符串長度

skill='java'echo ${skill} # 輸出結(jié)果: javaecho ${#skill} # 輸出結(jié)果: 4 [root@node01 export]# echo ${skill} java [root@node01 export]# echo ${#skill} 4

4 截取子字符串

substring(2)

substring(2,3)

以下實例從字符串第 2 個字符開始截取 4 個字符:

str="I am goot at $skill"echo ${str:2} # 輸出結(jié)果為: am goot at javaecho ${str:2:2} # 輸出結(jié)果為: am

5 查找子字符串

查找字符 io 的位置(哪個字母先出現(xiàn)就計算哪個):

str="I am goot at $skill" echo `expr index "$str" am` # 輸出是: 3

注意: 以上腳本中 ` 是反引號(Esc下面的),而不是單引號 ',不要看錯了哦。

2.5 傳遞參數(shù)

我們可以在執(zhí)行 Shell 腳本時,向腳本傳遞參數(shù),腳本內(nèi)獲取參數(shù)的格式為:$n

n 代表一個數(shù)字,1 為執(zhí)行腳本的第一個參數(shù),2 為執(zhí)行腳本的第二個參數(shù),以此類推……

實例

以下實例我們向腳本傳遞三個參數(shù),并分別輸出,其中 $0 為執(zhí)行的文件名:

vim /export/sh/param.sh

#!/bin/bashecho "Shell 傳遞參數(shù)實例!";echo "執(zhí)行的文件名:$0";echo "第一個參數(shù)為:$1";echo "第二個參數(shù)為:$2";echo "第三個參數(shù)為:$3";

為腳本設(shè)置可執(zhí)行權(quán)限,并執(zhí)行腳本,輸出結(jié)果如下所示:

$ chmod 755 param.sh $ ./param.sh 1 2 3

Shell 傳遞參數(shù)實例!

執(zhí)行的文件名:./param.sh第一個參數(shù)為:1第二個參數(shù)為:2第三個參數(shù)為:3

另外,還有幾個特殊字符用來處理參數(shù):

參數(shù)處理說明
$#傳遞到腳本的參數(shù)個數(shù)
$*以一個單字符串顯示所有向腳本傳遞的參數(shù)。 如"$*“用「”」括起來的情況、以"$1 $2 … $n"的形式輸出所有參數(shù)。
$$腳本運行的當(dāng)前進程ID號
$!后臺運行的最后一個進程的ID號
$@?相同,但是使用時加引號,并在引號中返回每個參數(shù)。如"*相同,但是使用時加引號,并在引號中返回每個參數(shù)。 如"?使數(shù)"@“用「”」括起來的情況、以"$1" “2"…"2" … "2""n” 的形式輸出所有參數(shù)。
$-顯示Shell使用的當(dāng)前選項,與set命令功能相同。
$?顯示最后命令的退出狀態(tài)。0表示沒有錯誤,其他任何值表明有錯誤。
#!/bin/bashecho "Shell 傳遞參數(shù)實例!";echo "第一個參數(shù)為:$1";echo "參數(shù)個數(shù)為:$#";echo "傳遞的參數(shù)作為一個字符串顯示:$*";

執(zhí)行腳本,輸出結(jié)果如下所示:

$ chmod +x test.sh $ ./test.sh 1 2 3Shell 傳遞參數(shù)實例!第一個參數(shù)為:1參數(shù)個數(shù)為:3傳遞的參數(shù)作為一個字符串顯示:1 2 3

$* 與 $@ 區(qū)別:

  • 相同點:都是引用所有參數(shù)。
  • 不同點:只有在雙引號中體現(xiàn)出來。假設(shè)在腳本運行時寫了三個參數(shù) 1、2、3,,則 " * " 等價于 “1 2 3”(傳遞了一個參數(shù)),而 “@” 等價于 “1” “2” “3”(傳遞了三個參數(shù))。
#!/bin/bashecho "-- $* 演示 ---" for i in "$*"; doecho $i doneecho "-- $@ 演示 ---" for i in "$@"; doecho $i done

執(zhí)行腳本,輸出結(jié)果如下所示:

$ chmod +x test.sh $ ./test.sh 1 2 3-- $* 演示 --- 1 2 3-- $@ 演示 --- 1 2 3

2.6 Shell算術(shù)運算符

1 簡介

Shell 和其他編程一樣,支持包括:算術(shù)、關(guān)系、布爾、字符串等運算符。

原生 bash **不支持 **簡單的數(shù)學(xué)運算,但是可以通過其他命令來實現(xiàn),例如expr。

expr 是一款表達式計算工具,使用它能完成表達式的求值操作。

例如,兩個數(shù)相加:

val=`expr 2 + 2` echo $val

i=2+2

注意:

表達式和運算符之間要有空格,例如 2+2 是不對的,必須寫成 2 + 2。

完整的表達式要被 ` 包含,注意不是單引號,在 Esc 鍵下邊。

下表列出了常用的算術(shù)運算符,假定變量 a 為 10,變量 b 為 20:

運算符說明舉例
+加法expr $a + $b 結(jié)果為 30。
-減法expr $a - $b 結(jié)果為 -10。
*乘法expr $a \* $b 結(jié)果為 200。
/除法expr $b / $a 結(jié)果為 2。
%取余expr $b % $a 結(jié)果為 0。
=賦值a=$b 將把變量 b 的值賦給 a。
==相等。用于比較兩個數(shù)字,相同則返回 true。[ $a == $b ] 返回 false。
!=不相等。用于比較兩個數(shù)字,不相同則返回 true。[ $a != $b ] 返回 true。

**注意:**條件表達式要放在方括號之間,并且要有空格,例如: [a==a==a==b] 是錯誤的,必須寫成 [ $a == $b ]

2 例子

#!/bin/basha=4b=20#加法運算each expr $a + $b#減法運算echo expr $a - $b#乘法運算,注意*號前面需要反斜杠echo expr $a \* $b#除法運算echo $a / $b此外,還可以通過(())、$(())、$[]進行算術(shù)運算。((a++))echo "a = $a"c=$((a + b))d=$[a + b]echo "c = $c"echo "d = $d"

2.7 流程控制

1 if else

1.1 if

if 語句語法格式:

if condition; thencommand1 command2...commandN fi

demo

[root@hadoop01 export]# cat if_test.sh #!/bin/basha=20if [ $a -gt 10 ]; thenecho "a 大于 10" fi

末尾的fi就是if倒過來拼寫,后面還會遇到類似的。

1.2 if else

if else 語法格式:

if condition; thencommand1command2...commandN elsecommand fi

1.3 if else-if else

if else-if else 語法格式:

if condition1; thencommand1 elif condition2; then command2 elsecommandN fi

以下實例判斷兩個變量是否相等:

關(guān)系運算符

關(guān)系運算符只支持數(shù)字,不支持字符串,除非字符串的值是數(shù)字。

下表列出了常用的關(guān)系運算符,假定變量 a 為 10,變量 b 為 20:

運算符說明英文舉例
-eq檢測兩個數(shù)是否相等,相等返回 true。equal[ $a -eq $b ] 返回 false。
-ne檢測兩個數(shù)是否不相等,不相等返回 true。not equal[ $a -ne $b ] 返回 true。
-gt檢測左邊的數(shù)是否大于右邊的,如果是,則返回 true。greater than[ $a -gt $b ] 返回 false。
-lt檢測左邊的數(shù)是否小于右邊的,如果是,則返回 true。less than[ $a -lt $b ] 返回 true。
-ge檢測左邊的數(shù)是否大于等于右邊的,如果是,則返回 true。Greater than or equal to[ $a -ge $b ] 返回 false。
-le檢測左邊的數(shù)是否小于等于右邊的,如果是,則返回 true。Less than or equal to[ $a -le $b ] 返回 true。

案例:

[root@hadoop01 export]# cat if_test.sh #!/bin/basha=20 b=10# 需求1: 判斷 a 是否 100 if [ $a > 100 ]; thenecho "$a 大于 100" fi# 需求2: 判斷 a 是否等于 b if [ $a -eq $b ]; thenecho "$a 等于 $b" elseecho "$a 不等于 $b" fi# 需求3: 判斷 a 與 b 比較 if [ $a -lt $b ]; thenecho "$a 小于 $b" elif [ $a -eq $b ]; thenecho "$a 等于 $b" elseecho "$a 大于 $b" fi# 需求4: 判斷 (a + 10) 和 (b * b) 比較大小 if test $[ a + 10 ] -gt $[ b * b ]; thenecho "(a+10) 大于 (b * b)" else echo "(a+10) 小于或等于 (b*b)" fi

2 for 循環(huán)

2.1 格式

for variable in (list); do commandcommand... done

2.2 隨堂練習(xí)

# 需求1: 遍歷 1~5 # 需求2: 遍歷 1~100 # 需求3: 遍歷 1~100之間的奇數(shù) # 需求4: 遍歷 根目錄 下的內(nèi)容

代碼如下:

[root@hadoop01 export]# cat for_test.sh #!/bin/bash# 需求1: 遍歷 1~5 for i in 1 2 3 4 5; doecho $i; donefor i in {1..5}; doecho $i donefor(( i=1; i<=5; i++ )); doecho $i done# 需求2: 遍歷 1~100 for i in {1..100}; doecho $i done# 需求3: 遍歷 1~100之間的奇數(shù) for i in {1..100..2}; doecho $i done# 需求4: 遍歷 根目錄 下的內(nèi)容 for f in `ls /`; doecho $f done

3 while 語句

while循環(huán)用于不斷執(zhí)行一系列命令,也用于從輸入文件中讀取數(shù)據(jù);命令通常為測試條件。其格式為:

while condition; docommand done

需求: 計算 1~100 的和

初始值; i=1

和值: sum=0;

while i<=100;

? sum = sum + i;

? i++;

打印 sum的值

#!/bin/bashsum=0 i=1 while [ $i -le 100 ]; dosum=$[ sum + i]i=$[ i + 1 ] doneecho $sum

運行腳本,輸出:

5050

使用中使用了 Bash let 命令,它用于執(zhí)行一個或多個表達式,變量計算中不需要加上 $ 來表示變量,具體可查閱:Bash let 命令。

4 無限循環(huán)

無限循環(huán)語法格式:

while true; docommand done 需求: 每隔1秒 打印一次當(dāng)前時間 #!/bin/bashwhile true; dodatesleep 1 done

5 case(switch)

Shell case語句為多選擇語句。可以用case語句匹配一個值與一個模式,如果匹配成功,執(zhí)行相匹配的命令。case語句格式如下:

casein模式1)command1command2...commandN;;模式2)command1command2...commandN;; esac

case工作方式如上所示。取值后面必須為單詞in,每一模式必須以右括號結(jié)束。取值可以為變量或常數(shù)。匹配發(fā)現(xiàn)取值符合某一模式后,其間所有命令開始執(zhí)行直至 ;;。

取值將檢測匹配的每一個模式。一旦模式匹配,則執(zhí)行完匹配模式相應(yīng)命令后不再繼續(xù)其他模式。如果無一匹配模式,使用星號 * 捕獲該值,再執(zhí)行后面的命令。

下面的腳本提示輸入1到4,與每一種模式進行匹配:

echo '輸入 1 到 4 之間的數(shù)字:'read aNumcase $aNum in1) echo '你選擇了 1';;2) echo '你選擇了 2';;3) echo '你選擇了 3';;4) echo '你選擇了 4';;*) echo '你沒有輸入 1 到 4 之間的數(shù)字';; esac

輸入不同的內(nèi)容,會有不同的結(jié)果,例如:

輸入 1 到 4 之間的數(shù)字:你輸入的數(shù)字為:3你選擇了 3

?

6 跳出循環(huán)

在循環(huán)過程中,有時候需要在未達到循環(huán)結(jié)束條件時強制跳出循環(huán),Shell使用兩個命令來實現(xiàn)該功能:break和continue。

6.1 break命令

break命令允許跳出所有循環(huán)(終止執(zhí)行后面的所有循環(huán))。

需求: 執(zhí)行死循環(huán) 每隔1秒打印當(dāng)前時間, 執(zhí)行10次停止 #!/bin/bash # 需求: 執(zhí)行死循環(huán) 每隔1秒打印當(dāng)前時間, 執(zhí)行10次停止 i=0; while true; dosleep 1echo $i `date +"%Y-%m-%d %H:%M:%S"`i=$[ i + 1]if [ $i -eq 10 ]; thenbreakfi done

6.2 continue

continue命令與break命令類似,只有一點差別,它不會跳出所有循環(huán),僅僅跳出當(dāng)前循環(huán)。

需求: 打印 1~30, 注意 跳過3的倍數(shù) #!/bin/bash# 需求: 打印 1~30, 注意 跳過3的倍數(shù)for i in {1..30}; doif test $[ i % 3 ] -eq 0; thencontinuefiecho $i done

2.8 函數(shù)使用

1 函數(shù)的快速入門

  • 格式

    [ function ] funname() {action;[return int;] }
    • 可以帶function fun() 定義,也可以直接fun() 定義,不帶任何參數(shù)。
    • 參數(shù)返回,可以顯示加:return 返回,如果不加,將以最后一條命令運行結(jié)果,作為返回值。 return后跟數(shù)值n(0-255)
  • 快速入門

    #!/bin/bashdemoFun () {echo "這是我的第一個 shell 函數(shù)!"}echo "-----函數(shù)開始執(zhí)行-----" demoFun echo "-----函數(shù)執(zhí)行完畢-----"

2 傳遞參數(shù)給函數(shù)

在Shell中,調(diào)用函數(shù)時可以向其傳遞參數(shù)。在函數(shù)體內(nèi)部,通過 $n 的形式來獲取參數(shù)的值,例如,$1表示第一個參數(shù),$2表示第二個參數(shù)…

帶參數(shù)的函數(shù)示例:

#!/bin/bashfunWithParam(){echo "第一個參數(shù)為 $1 !"echo "第二個參數(shù)為 $2 !"echo "第十個參數(shù)為 $10 !"echo "第十個參數(shù)為 ${10} !"echo "第十一個參數(shù)為 ${11} !"echo "參數(shù)總數(shù)有 $# 個!"echo "作為一個字符串輸出所有參數(shù) $* !" }funWithParam 1 2 3 4 5 6 7 8 9 34 73

輸出結(jié)果:

第一個參數(shù)為 1 !第二個參數(shù)為 2 !第十個參數(shù)為 10 !第十個參數(shù)為 34 !第十一個參數(shù)為 73 !參數(shù)總數(shù)有 11 個!作為一個字符串輸出所有參數(shù) 1 2 3 4 5 6 7 8 9 34 73 !

注意,10不能獲取第十個參數(shù),獲取第十個參數(shù)需要10 不能獲取第十個參數(shù),獲取第十個參數(shù)需要10數(shù)數(shù){10}。當(dāng)n>=10時,需要使用${n}來獲取參數(shù)。

另外,還有幾個特殊字符用來處理參數(shù):

參數(shù)處理說明
$#傳遞到腳本的參數(shù)個數(shù)
$*以一個單字符串顯示所有向腳本傳遞的參數(shù)
$$腳本運行的當(dāng)前進程ID號
$!后臺運行的最后一個進程的ID號
$@與$*相同,但是使用時加引號,并在引號中返回每個參數(shù)。
$-顯示Shell使用的當(dāng)前選項,與set命令功能相同。
$?顯示最后命令的退出狀態(tài)。0表示沒有錯誤,其他任何值表明有錯誤。

0 1 2

2.9 數(shù)組

1 定義數(shù)組

數(shù)組中可以存放多個值。Bash Shell 只支持一維數(shù)組(不支持多維數(shù)組),初始化時不需要定義數(shù)組大小

與大部分編程語言類似,數(shù)組元素的下標由0開始。

Shell 數(shù)組用括號來表示,元素用**“空格”**符號分割開,語法格式如下:

array_name=(value1 value2 value3 … valuen)

1.1 實例

#!/bin/bashmy_array=(A B "C" D)我們也可以使用下標來定義數(shù)組:array_name[0]=value0array_name[1]=value1array_name[2]=value2

2 讀取數(shù)組

讀取數(shù)組元素值的一般格式是:

${array_name[index]}

2.1 實例

#!/bin/bashmy_array=(A B "C" D)echo "第一個元素為: ${my_array[0]}"echo "第二個元素為: ${my_array[1]}"echo "第三個元素為: ${my_array[2]}"echo "第四個元素為: ${my_array[3]}"

執(zhí)行腳本,輸出結(jié)果如下所示:

$ chmod +x test.sh $ ./test.sh第一個元素為: A 第二個元素為: B 第三個元素為: C 第四個元素為: D

2.2 獲取數(shù)組中的所有元素

使用@ 或 * 可以獲取數(shù)組中的所有元素,例如:

#!/bin/bashmy_array[0]=A my_array[1]=B my_array[2]=C my_array[3]=Decho "數(shù)組的元素為: ${my_array[*]}" echo "數(shù)組的元素為: ${my_array[@]}"

執(zhí)行腳本,輸出結(jié)果如下所示:

$ chmod +x test.sh $ ./test.sh數(shù)組的元素為: A B C D 數(shù)組的元素為: A B C D

2.3 獲取數(shù)組的長度

獲取數(shù)組長度的方法與獲取字符串長度的方法相同,例如:

#!/bin/bash my_array[0]=A my_array[1]=B my_array[2]=C my_array[3]=Decho "數(shù)組元素個數(shù)為: ${#my_array[*]}" echo "數(shù)組元素個數(shù)為: ${#my_array[@]}"

執(zhí)行腳本,輸出結(jié)果如下所示:

$ chmod +x test.sh $ ./test.sh數(shù)組元素個數(shù)為: 4 數(shù)組元素個數(shù)為: 4

3 遍歷數(shù)組

3.1 方式一

#!/bin/bashmy_arr=(AA BB CC)for var in ${my_arr[*]} doecho $var done

3.2 方式二

my_arr=(AA BB CC) my_arr_num=${#my_arr[*]} for((i=0;i<my_arr_num;i++)); doecho "-----------------------------"echo ${my_arr[$i]} done

2.10 加載其它文件的變量

1 簡介

和其他語言一樣,Shell 也可以包含外部腳本。這樣可以很方便的封裝一些公用的代碼作為一個獨立的文件。

Shell 文件包含的語法格式如下:

. filename # 注意點號(.)和文件名中間有一空格或source filename

2 練習(xí)

定義兩個文件 test1.sh和test2.sh,在test1中定義一個變量arr=(java c++ shell),在test2中對arr進行循環(huán)打印輸出。

第一步: vim test1.sh

#!/bin/bashmy_arr=(AA BB CC)

第二步: vim test2.sh

#!/bin/bashsource ./test1.sh # 加載test1.sh 的文件內(nèi)容for var in ${my_arr[*]}doecho $vardone

第三步: 執(zhí)行 test2.sh

sh test2.sh

好處 :

? 1. 數(shù)據(jù)源 和 業(yè)務(wù)處理 分離

? 2. 復(fù)用 代碼擴展性更強

總結(jié)

以上是生活随笔為你收集整理的linux基础-3的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。