案例:從頭開始匹配,將符合最短的數據刪除 (#)java
variable_1="I love you, Do you love me" echo $variable_1 variable_2=${variable_1#*ov} echo $variable_2
案例:從頭開始匹配,將複合最短的數據刪除(##)python
varible_3=${variable_1##*ov} echo $varible_3
案例:替換字符串,只替換第一次匹配成功的(/)nginx
echo $PATH var6=${PATH/bin/BIN} echo $var6
案例:替換字符串,符合條件的所有替換 (//)shell
var7=${PATH//bin/BIN} echo $var7
簡單舉例(用的比較少)編程
var=${str-expr}
若是變量 str 沒有定義,那麼var=expr數組
若是變量 str的字符串中有值,那麼 變量 var 的值就等於 str變量的值bash
計算字符串的長度app
案例1函數
var="hello world" len=${#var} echo $len
案例2oop
var1="zhang biao" len=`expr length "$var1"` echo $len
獲取字串在字符串中的索引位置 (把字串拆分紅一個個的字串,最早匹配到的第一個就會返回)
案例
var="quickstart is a app" ind=`expr index "$var" start` echo $ind
案例 查找一個不存在的字串,返回 1
ind=`expr index "$var" uniq` echo $ind
計算字串的長度 (只能從頭開始匹配,用的很少)
例子:找不到返回 0,不是從頭開始匹配
var="quickstart is a app" sub_len=`expr match "$var1" app` echo $sub_len
從頭開始匹配
sub_len=`expr match "$var" quick*` echo $sub_len
sub_len=`expr match "$var" quick.*` echo $sub_len
抽取字串
案例:方法一
提取var1中索引從10開始一直到結尾的字符串,索引下標從0開始
var1="kafka hadoop yarn mapreduce" sub_str1=${var1:10} echo $sub_str1
案例:方法二
從第10個位置開始提取5個字符串
sub_str2=${var1:10:5} echo $sub_str2
案例:方法三
取最後的5位
sub_str3=${var1: -5} echo $sub_str3
案例:方法四
取從最後開始取最後5位,注意 var1: -5 之間有空格
sub_str3=${var1:(-5)} echo $sub_str3
案例:方法五
提取最後5位的前兩位
sub_str3=${var1: -5:2} echo $sub_str3
注意: 使用expr,索引計數是從1開始計算 使用${string:position},索引計數是從0開始
需求描述:
變量 string="Bigdata process framework is Hadoop,Hadoop is an open source project"
執行腳本後,打印輸出string字符串變量,並給出用戶如下選項:
思路分析:
一、將不一樣的功能模塊劃分,並編寫函數、
二、實現第一步所定義的功能函數
#!/bin/bash # string="Bigdata process framework is Hadoop,Hadoop is an open source project" function print_tips { echo "********************************************" echo "(1)打印string長度" echo "(2)刪除字符串中全部的Hadoop" echo "(3)替換第一個Hadoop爲Mapreduce" echo "(4)替換所有Hadoop爲Mapreduce" echo "********************************************" } function len_of_string { echo "${#string}" } function del_hadoop { # 把hadoop替換爲空 echo "${string//Hadoop/}" } function rep_hadoop_mapreduce_first { echo "${string/Hadoop/Mapreduce}" } function rep_hadoop_mapreduce_all { echo "${string//Hadoop/Mapreduce}" }
三、程序主流程的設計
example.sh
#!/bin/bash # string="Bigdata process framework is Hadoop,Hadoop is an open source project" function print_tips { echo "********************************************" echo "(1) 打印string長度" echo "(2) 刪除字符串中全部的Hadoop" echo "(3) 替換第一個Hadoop爲Mapreduce" echo "(4) 替換所有Hadoop爲Mapreduce" echo "********************************************" } function len_of_string { echo "${#string}" } function del_hadoop { # 把hadoop替換爲空 echo "${string//Hadoop/}" } function rep_hadoop_mapreduce_first { echo "${string/Hadoop/Mapreduce}" } function rep_hadoop_mapreduce_all { echo "${string//Hadoop/Mapreduce}" } while true do echo " 【string=$string】" echo print_tips read -p "Pls input your choice(1|2|3|4|q|Q):" choice case $choice in 1) len_of_string ;; 2) del_hadoop ;; 3) rep_hadoop_mapreduce_first ;; 4) rep_hadoop_mapreduce_all ;; q|Q) exit ;; *) echo "Error,input only in {1|2|3|4|q|Q}" ;; esac done
語法格式
例子1: 獲取系統的全部用戶並輸
使用 cut 對 : 進行切割,獲取第一個及時用戶的名字
cat /etc/passwd | cut -d ":" -f 1
for循環能以空格、換行、tab鍵做爲分隔符
sys_user.sh
#!/bin/bash # index=1 for user in `cat /etc/passwd | cut -d ":" -f 1` do echo "this is $index user: $user" index=$(($index + 1)) done
例子2: 根據系統時間計算今年或明年
echo "this is $(date +%Y) year" echo "this is $(( $(date +%Y) + 1)) year"
總結: ``和$()二者是等價的,但推薦初學者使用$(),易於掌握;缺點是極少數UNIX可能不支持,但``二者都支持 $(())主要用來進行整數運算,包括加減乘除,引用變量前面能夠加$,也能夠不加$
echo "$((20+30))"
示例3
echo $((100+30)) echo $(( (100 + 30) / 13 )) echo $(( $num1 + $num2 * 2))
shell 語法不是很嚴格,是否加$都會計算
num1=50 num2=70 echo "$((num1 + num2))"
例子4:
今天是今年的第多少天
echo $(date +%j)
根據系統時間獲取今年還剩下多少星期,已通過了多少星期
echo "this year have passed $(date +%j) days" echo "this year have passed $(($(date +%j) / 7)) weeks"
今年還剩餘多少天
echo "there is $((365 - $(date +%j))) days before new year" echo "there is $(((365 - $(date +%j)) / 7 )) weeks before new year"
示例5:判斷nginx進程是否存在,若是沒有需求拉起這個進程
example_3.sh
#!/bin/bash # # grep -v 過濾掉 grep 進程 nginx_process_num=$(ps -ef|grep nginx|grep -v grep|wc -l) if [ $nginx_process_num -eq 0 ];then systemctl start nginx fi
shell編程系列4--有類型變量:字符串、只讀類型、整數、數組
declare -r 將變量設置爲只讀類型
var2="hello python" declare -r var2 var2="hello java"
declare -i 將變量設爲整數
默認把變量當作字符處理
num1=10 num2=$num1+20 echo $num2
聲明爲整數
declare -i num3 num3=$num1+90 echo $num3
declare -a 將變量定義爲數組
定義數組
declare -a array array=("jones" "make" "kobe" "jordan")
列出數組全部元素
echo ${array[@]}
列出其中指定的一個
echo ${array[1]}
計算數組長度
echo ${#array[@]}
輸出數組中元素長度
echo ${#array[0]}
-f 顯示此腳本前定義過的全部函數和內容 ,-F 進顯示腳本前定義過的函數名
declare -f declare -F
數組經常使用的方法(僅供參考,實際生產用的少)
array=("jones" "mike" "kobe" "jordan") 輸出數組內容: echo ${array[@]} 輸出所有內容 echo ${array[1]} 輸出下標索引爲1的內容 獲取數組長度: echo ${#array} 數組內元素個數 echo ${#array[2]} 數組內下標索引爲2的元素長度 給數組某個下標賦值: array[0]="lily" 給數組下標索引爲1的元素賦值爲lily array[20]="hanmeimei" 在數組尾部添加一個新元素 刪除元素: unset array[2] 清空元素 unset array 清空整個數組 分片訪問: ${array[@]:1:4} 顯示數組下標索引從1開始到3的3個元素 內容替換: ${array[@]/an/AN} 將數組中全部元素包含an的子串替換爲AN 數組遍歷: for v in ${array[@]} do echo $v done
declare -x 將變量聲明爲環境變量
test1.sh
#!/bin/bash # echo $num5
運行 sh test1.sh
當使用declare -x 變量後,就能夠直接在腳本中引用了
num5=30 declare -x num5