linux基础-3
| 管道相關(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ù)
| -c | characters | 按字符選取內(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)容
| -d '分隔符' | delimiter | 指定分隔符 |
| -f n1,n2 | fields | 分割以后顯示第幾段內(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-31.3 小結(jié)
- 通過 cut 動作 目標文件 可以根據(jù)條件 提取對應(yīng)內(nèi)容
2 sort 的 工作原理
2.1 目標
- sort可針對文本文件的內(nèi)容,以行為單位來排序。
2.2 路徑
- 第一步: 對字符串排序
- 第二步: 去重排序
- 第三步: 對數(shù)值排序
- 第四步: 對成績排序
2.3 實現(xiàn)
第一步: 對字符串排序
- 準備工作
第二步: 去重排序
| -u | unique | 去掉重復(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ù)值排序
| -n | numeric-sort | 按照數(shù)值大小排序 |
| -r | reverse | 使次序顛倒 |
-
準備數(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
第四步: 對成績排序
| -t | field-separator | 指定字段分隔符 |
| -k | key | 根據(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ù) 信息.
第二步: 只顯示 文件 的行數(shù)
| -c | bytes | 字節(jié)數(shù) |
| -w | words | 單詞數(shù) |
| -l | lines | 行數(shù) |
第三步: 統(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 -l3.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ù)
| -c | count | 統(tǒng)計每行內(nèi)容出現(xiàn)的次數(shù) |
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)成 小寫
第二步: 實現(xiàn)刪除效果
| 命令結(jié)果 | tr -d 被刪除的字符 | delete | 刪除指定的字符 |
- 需求: 刪除abc1d4e5f中的數(shù)字
第三步: 單詞計數(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的小文件 |
第二步: 按 行數(shù) 將 大文件 切分成 若干小文件
| split -l 1000 文件 | lines | 將大文件切分成若干1000行 的小文件 |
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 | 模糊查詢 |
第二步: 指定分割符, 根據(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)容 | |
| NF | field | 表示當(dāng)前行共有多少個字段 |
| $NF | 代表 最后一個字段 | |
| $(NF-1) | 代表 倒數(shù)第二個字段 | |
| NR | 代表 處理的是第幾行 |
第三步: 指定分割符, 根據(jù)下標顯示內(nèi)容
| awk -F ’ ’ ‘{OFS="==="}{print $1, $2, $3}’ 1.txt | 操作1.txt文件, 根據(jù) 逗號 分割, 打印 第一段 第二段 第三段 內(nèi)容 |
選項
| OFS="字符" | output field separator | 向外輸出時的段分割字符串 |
| \b | 退格 |
| \f | 換頁 |
| \n | 換行 |
| \r | 回車 |
| \t | 制表符 |
第四步: 調(diào)用 awk 提供的函數(shù)
| awk -F ‘,’ ‘{print toupper($2)}’ 1.txt | 操作1.txt文件, 根據(jù) 逗號 分割, 打印 第一段 第二段 第三段 內(nèi)容 |
常用函數(shù)如下:
| toupper() | upper | 字符 轉(zhuǎn)成 大寫 |
| tolower() | lower | 字符 轉(zhuǎn)成小寫 |
| length() | length | 返回 字符長度 |
第五步: 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, 是否及格 |
選項
| 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)容 |
第六步: 段內(nèi)容 求指定學(xué)科平均分
| awk ‘BEGIN{初始化操作}{每行都執(zhí)行} END{結(jié)束時操作}’ 文件名 | BEGIN{ 這里面放的是執(zhí)行前的語句 } {這里面放的是處理每一行時要執(zhí)行的語句} END {這里面放的是處理完所有的行后要執(zhí)行的語句 } |
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ù)
| p | 打印 | |
| $ | 代表 最后一行 | |
| -n | 僅顯示處理后的結(jié)果 | |
| -e | expression | 根據(jù)表達式 進行處理 |
-
練習(xí)1 列出 1.txt的 3~5行 的數(shù)據(jù)
-
練習(xí)2 列出01.txt的所有數(shù)據(jù)
-
練習(xí)3 列出01.txt的3-5行數(shù)據(jù) 且 顯示行號
| = | 打印當(dāng)前行號 |
-
練習(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ū)分大小寫,并顯示行號
| I | ignore | 忽略大小寫 |
答案:
[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的行,并顯示行號
| -r | regexp-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ù),并顯示行號
| d | delete | 刪除指定內(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,并顯示行號
| i | insert | 目標前面 插入內(nèi)容 |
| a | append | 目標后面 追加內(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
| -i | in-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 rttt2. 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/csh2.2快速入門
1 編寫腳本
新建 /export/01.sh 文件
#!/bin/bashecho 'hello world'#!是一個約定的標記,它告訴系統(tǒng)這個腳本需要什么解釋器來執(zhí)行,即使用哪一種 Shell。
echo 命令用于向窗口輸出文本。
2 執(zhí)行shell腳本
-
執(zhí)行方式一
-
問題: bash 和 sh 是什么關(guān)系?
sh 是 bash 的 快捷方式
3.2 執(zhí)行方式二
方式一的簡化方式
[root@node04 shells]# bash hello.sh hello world[root@node04 shells]# sh hello.sh hello world3.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" zhangsanlikebanana3 刪除變量
使用 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} 44 截取子字符串
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é)果為: am5 查找子字符串
查找字符 i 或 o 的位置(哪個字母先出現(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 3Shell 傳遞參數(shù)實例!
執(zhí)行的文件名:./param.sh第一個參數(shù)為:1第二個參數(shù)為:2第三個參數(shù)為:3另外,還有幾個特殊字符用來處理參數(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表示沒有錯誤,其他任何值表明有錯誤。 |
執(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ù))。
執(zhí)行腳本,輸出結(jié)果如下所示:
$ chmod +x test.sh $ ./test.sh 1 2 3-- $* 演示 --- 1 2 3-- $@ 演示 --- 1 2 32.6 Shell算術(shù)運算符
1 簡介
Shell 和其他編程一樣,支持包括:算術(shù)、關(guān)系、布爾、字符串等運算符。
原生 bash **不支持 **簡單的數(shù)學(xué)運算,但是可以通過其他命令來實現(xiàn),例如expr。
expr 是一款表達式計算工具,使用它能完成表達式的求值操作。
例如,兩個數(shù)相加:
val=`expr 2 + 2` echo $vali=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 fidemo
[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 fi1.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)" fi2 for 循環(huán)
2.1 格式
for variable in (list); do commandcommand... done2.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 done3 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 done5 case(switch)
Shell case語句為多選擇語句。可以用case語句匹配一個值與一個模式,如果匹配成功,執(zhí)行相匹配的命令。case語句格式如下:
case 值 in模式1)command1command2...commandN;;模式2)command1command2...commandN;; esaccase工作方式如上所示。取值后面必須為單詞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 done6.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 done2.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ù) |
| $$ | 腳本運行的當(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]=value22 讀取數(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 第四個元素為: D2.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 D2.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ù)為: 43 遍歷數(shù)組
3.1 方式一
#!/bin/bashmy_arr=(AA BB CC)for var in ${my_arr[*]} doecho $var done3.2 方式二
my_arr=(AA BB CC) my_arr_num=${#my_arr[*]} for((i=0;i<my_arr_num;i++)); doecho "-----------------------------"echo ${my_arr[$i]} done2.10 加載其它文件的變量
1 簡介
和其他語言一樣,Shell 也可以包含外部腳本。這樣可以很方便的封裝一些公用的代碼作為一個獨立的文件。
Shell 文件包含的語法格式如下:
. filename # 注意點號(.)和文件名中間有一空格或source filename2 練習(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é)
- 上一篇: 三维GIS技术应用
- 下一篇: Linux下安装nginx教程