核心知識點(一)變量的高級用法
變量的高級用法
變量替換
語法 | 說明 |
---|---|
${變量名#匹配規則} | 從變量開頭 進行規則匹配,將符合最短的數據刪除 |
${變量名##匹配規則} | 從變量開頭 進行規則匹配,將符合最長的數據刪除 |
${變量名%匹配規則} | 從變量尾部 進行規則匹配,將符合最短的數據刪除 |
${變量名%%匹配規則} | 從變量尾部 進行規則匹配,將符合最長的數據刪除 |
${變量名/舊字符串/新字符串} | 變量內容 符合舊字符串 ,則第一個舊字符串會被新字符串 取代 |
${變量名//舊字符串/新字符串} | 變量內容 符合舊字符串 ,則所有的舊字符串會被新字符串 取代 |
演示demo
[wanghui@www ~]$ variable_1="i love shell,Do you love shell?"
[wanghui@www ~]$ echo "${variable_1}"
i love shell,Do you love shell?
[wanghui@www ~]$ var1=${variable_1#*ov}
[wanghui@www ~]$ echo $var1
e shell,Do you love shell?
[wanghui@www ~]$ var2=${variable_1##*ov} #貪婪模式
[wanghui@www ~]$ echo $var2
e shell?
[wanghui@www ~]$ var3=${variable_1%ov*}
[wanghui@www ~]$ echo $var3
i love shell,Do you l
[wanghui@www ~]$ var4=${variable_1%%ov*}
[wanghui@www ~]$ echo $var4
i l
[root@www ~]# var5="/usr/local/node/bin:/opt/application/go_1_11/bin:/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin"
[root@www ~]# var_5=${var5/bin/BIN}
[root@www ~]# echo $var_5
/usr/local/node/BIN:/opt/application/go_1_11/bin:/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin
[root@www ~]# var_6=${var5//bin/BIN}
[root@www ~]# echo $var_6
/usr/local/node/BIN:/opt/application/go_1_11/BIN:/usr/local/sBIN:/usr/local/BIN:/sBIN:/BIN:/usr/sBIN:/usr/BIN:/root/BIN
變量測試
image.png
字符串處理
計算字符串長度
方法類型 | 語法 | 說明 |
---|---|---|
方法一 | ${#string} | 無 |
方法二 | expr length "$string" | string有空格,則必須加雙引號 |
[wanghui@www shell_script]$ var1="hello world"
[wanghui@www shell_script]$ len1=${#var1}
[wanghui@www shell_script]$ len1_new=`expr length "$var1"`
[wanghui@www shell_script]$ echo $len1
11
[wanghui@www shell_script]$ echo $len1_new
11
獲取子串在字符串中的索引位置
語法 | 方式 |
---|---|
- | expr index $string $substring |
[wanghui@www shell_script]$ var1="quickstart is a app"
[wanghui@www shell_script]$ ind=`expr index "$var1" start`
[wanghui@www shell_script]$ echo $ind
6
[wanghui@www shell_script]$ ind=`expr index "$var1" uniq`
[wanghui@www shell_script]$ echo $ind
1
計算子串的長度
子串要從頭開始
語法 | 方式 |
---|---|
- | expr match $string substring |
[wanghui@www shell_script]$ var1="quickstart is a app"
[wanghui@www shell_script]$ sub_len=`expr match "$var1" quick`
[wanghui@www shell_script]$ echo $sub_len
5
[wanghui@www shell_script]$ sub_len=`expr match "$var1" quick.*`
[wanghui@www shell_script]$ echo $sub_len
19
抽取子串(切片)
image.png
[wanghui@www shell_script]$ echo $var1
kafka hadoop yarn mapreduce
[wanghui@www shell_script]$ substr1=${var1:10}
[wanghui@www shell_script]$ echo $substr1
op yarn mapreduce
[wanghui@www shell_script]$ substr2=${var1:10:5}
[wanghui@www shell_script]$ echo $substr2
op ya
[wanghui@www shell_script]$ substr3=${var1: -5} #-5前面有空格
[wanghui@www shell_script]$ echo $substr3
educe
[wanghui@www shell_script]$ substr4=${var1:(-5)} #這種不需要定格寫
[wanghui@www shell_script]$ echo $substr4
educe
[wanghui@www shell_script]$ substr5=`expr substr "$var1" 10 5` #expr從1開始計數,其他的是從0開始計數
[wanghui@www shell_script]$ echo $substr5
oop y
練習
練習一
需求描述
變量string="Bigdata process framework is Hadoop,Hadoop is an open source project",執行腳本后打印出string字符串變量,并給出用戶以下選項:
(1)打印string長度
(2)刪除字符串中的Hadoop
(3)替換第一個Hadoop為Mapreduce
(4)替換全部Hadoop為Mapreduce
用戶輸入數字1|2|3|4可以執行對應的功能,輸入Q|q則退出交互模式
思路分析:
- 劃分不同的功能模塊,并寫函數
function print_tips
function len_of_string
function del_hadoop
function req_hadoop_mapreduce_first
function req_hadoop_mapreduce_all
- 實現第一步定義的功能函數
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
{
echo "${string//Hadoop/}"
}
function req_hadoop_mapreduce_first
{
echo "${string/Hadoop/Mapreduce}"
}
function req_hadoop_mapreduce_all
{
echo "${string//Hadoop/Mapreduce}"
}
- 程序主流程的設置
while true
do
echo "【string=$string】"
echo
print_tips
read -p "Please input your choice(1|2|3|4|q|Q):" choice
case $choice in
1)
len_of_string
;;
2)
del_hadoop
;;
3)
req_hadoop_mapreduce_first
;;
4)
req_hadoop_mapreduce_all
;;
q|Q)
exit
;;
*)
echo "Error,input only in {1|2|3|4|q|Q}"
;;
esac
done
完整代碼如下
#!/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
{
echo "${string//Hadoop/}"
}
function req_hadoop_mapreduce_first
{
echo "${string/Hadoop/Mapreduce}"
}
function req_hadoop_mapreduce_all
{
echo "${string//Hadoop/Mapreduce}"
}
while true
do
echo "【string=$string】"
echo
print_tips
read -p "Please input your choice(1|2|3|4|q|Q):" choice
case $choice in
1)
len_of_string
;;
2)
del_hadoop
;;
3)
req_hadoop_mapreduce_first
;;
4)
req_hadoop_mapreduce_all
;;
q|Q)
exit
;;
*)
echo "Error,input only in {1|2|3|4|q|Q}"
;;
esac
done