目錄
- 變量刪除和替換
- 變量測(cè)試
- 字符串處理
- 字符串處理完整腳本
- 命令替換
- 有類型變量
變量刪除和替換
案例:從頭開(kāi)始匹配,將符合最短的數(shù)據(jù)刪除 (#)
variable_1="I love you, Do you love me"
echo $variable_1
variable_2=${variable_1#*ov}
echo $variable_2
案例:從頭開(kāi)始匹配,將復(fù)合最短的數(shù)據(jù)刪除(##)
varible_3=${variable_1##*ov}
echo $varible_3
案例:替換字符串,只替換第一次匹配成功的(/)
echo $PATH
var6=${PATH/bin/BIN}
echo $var6
案例:替換字符串,符合條件的全部替換 (//)
var7=${PATH//bin/BIN}
echo $var7
變量測(cè)試
簡(jiǎn)單舉例(用的比較少)
如果變量 str 沒(méi)有定義,那么var=expr
如果變量 str的字符串中有值,那么 變量 var 的值就等于 str變量的值
字符串處理
計(jì)算字符串的長(zhǎng)度
案例1
var="hello world"
len=${#var}
echo $len
案例2
var1="zhang biao"
len=`expr length "$var1"`
echo $len
獲取字串在字符串中的索引位置 (把字串拆分成一個(gè)個(gè)的字串,最先匹配到的第一個(gè)就會(huì)返回)
案例
var="quickstart is a app"
ind=`expr index "$var" start`
echo $ind
案例 查找一個(gè)不存在的字串,返回 1
ind=`expr index "$var" uniq`
echo $ind
計(jì)算字串的長(zhǎng)度 (只能從頭開(kāi)始匹配,用的不多)
例子:找不到返回 0,不是從頭開(kāi)始匹配
var="quickstart is a app"
sub_len=`expr match "$var1" app`
echo $sub_len
從頭開(kāi)始匹配
sub_len=`expr match "$var" quick*`
echo $sub_len
sub_len=`expr match "$var" quick.*`
echo $sub_len
抽取字串
案例:方法一
提取var1中索引從10開(kāi)始一直到結(jié)尾的字符串,索引下標(biāo)從0開(kāi)始
var1="kafka hadoop yarn mapreduce"
sub_str1=${var1:10}
echo $sub_str1
案例:方法二
從第10個(gè)位置開(kāi)始提取5個(gè)字符串
sub_str2=${var1:10:5}
echo $sub_str2
案例:方法三
取最后的5位
sub_str3=${var1: -5}
echo $sub_str3
案例:方法四
取從最后開(kāi)始取最后5位,注意 var1: -5 之間有空格
sub_str3=${var1:(-5)}
echo $sub_str3
案例:方法五
提取最后5位的前兩位
sub_str3=${var1: -5:2}
echo $sub_str3
注意: 使用expr,索引計(jì)數(shù)是從1開(kāi)始計(jì)算 使用${string:position},索引計(jì)數(shù)是從0開(kāi)始
字符串處理完整腳本
需求描述:
變量 string="Bigdata process framework is Hadoop,Hadoop is an open source project"
執(zhí)行腳本后,打印輸出string字符串變量,并給出用戶以下選項(xiàng):
(1)、打印string長(zhǎng)度
(2)、刪除字符串中所有的Hadoop
(3)、替換第一個(gè)Hadoop為Mapreduce
(4)、替換全部Hadoop為Mapreduce用戶輸入數(shù)字1|2|3|4,可以執(zhí)行對(duì)應(yīng)項(xiàng)中的功能;輸入q|Q則退出交互模式
思路分析:
1、將不同的功能模塊劃分,并編寫函數(shù)、
- function print_tips
- function len_of_string
- function del_hadoop
- function rep_hadoop_mapreduce_first
- function rep_hadoop_mapreduce_all
2、實(shí)現(xiàn)第一步所定義的功能函數(shù)
#!/bin/bash
#
string="Bigdata process framework is Hadoop,Hadoop is an open source project"
function print_tips
{
echo "********************************************"
echo "(1)打印string長(zhǎng)度"
echo "(2)刪除字符串中所有的Hadoop"
echo "(3)替換第一個(gè)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}"
}
3、程序主流程的設(shè)計(jì)
example.sh
#!/bin/bash
#
string="Bigdata process framework is Hadoop,Hadoop is an open source project"
function print_tips
{
echo "********************************************"
echo "(1) 打印string長(zhǎng)度"
echo "(2) 刪除字符串中所有的Hadoop"
echo "(3) 替換第一個(gè)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
命令替換
語(yǔ)法格式
例子1: 獲取系統(tǒng)的所有用戶并輸
cat /etc/passwd | cut -d ":" -f 1
使用 cut 對(duì) : 進(jìn)行切割,獲取第一個(gè)及時(shí)用戶的名字
for循環(huán)能以空格、換行、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: 根據(jù)系統(tǒng)時(shí)間計(jì)算今年或明年
echo "this is $(date +%Y) year"
echo "this is $(( $(date +%Y) + 1)) year"
總結(jié): ``和$()兩者是等價(jià)的,但推薦初學(xué)者使用$(),易于掌握;缺點(diǎn)是極少數(shù)UNIX可能不支持,但``兩者都支持 $(())主要用來(lái)進(jìn)行整數(shù)運(yùn)算,包括加減乘除,引用變量前面可以加$,也可以不加$
示例3
echo $((100+30))
echo $(( (100 + 30) / 13 ))
echo $(( $num1 + $num2 * 2))
shell 語(yǔ)法不是很嚴(yán)格,是否加$都會(huì)計(jì)算
num1=50
num2=70
echo "$((num1 + num2))"
例子4:
今天是今年的第多少天
根據(jù)系統(tǒng)時(shí)間獲取今年還剩下多少星期,已經(jīng)過(guò)了多少星期
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進(jìn)程是否存在,如果沒(méi)有需求拉起這個(gè)進(jìn)程
example_3.sh
#!/bin/bash
#
# grep -v 過(guò)濾掉 grep 進(jìn)程
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--有類型變量:字符串、只讀類型、整數(shù)、數(shù)組
declare -r 將變量設(shè)置為只讀類型
var2="hello python"
declare -r var2
var2="hello java"
declare -i 將變量設(shè)為整數(shù)
默認(rèn)把變量當(dāng)做字符處理
num1=10
num2=$num1+20
echo $num2
聲明為整數(shù)
declare -i num3
num3=$num1+90
echo $num3
declare -a 將變量定義為數(shù)組
定義數(shù)組
declare -a array
array=("jones" "make" "kobe" "jordan")
列出數(shù)組所有元素
列出其中指定的一個(gè)
計(jì)算數(shù)組長(zhǎng)度
輸出數(shù)組中元素長(zhǎng)度
-f 顯示此腳本前定義過(guò)的所有函數(shù)和內(nèi)容 ,-F 進(jìn)顯示腳本前定義過(guò)的函數(shù)名
數(shù)組常用的方法(僅供參考,實(shí)際生產(chǎn)用的少)
array=("jones" "mike" "kobe" "jordan")
輸出數(shù)組內(nèi)容:
echo ${array[@]} 輸出全部?jī)?nèi)容
echo ${array[1]} 輸出下標(biāo)索引為1的內(nèi)容
獲取數(shù)組長(zhǎng)度:
echo ${#array} 數(shù)組內(nèi)元素個(gè)數(shù)
echo ${#array[2]} 數(shù)組內(nèi)下標(biāo)索引為2的元素長(zhǎng)度
給數(shù)組某個(gè)下標(biāo)賦值:
array[0]="lily" 給數(shù)組下標(biāo)索引為1的元素賦值為lily
array[20]="hanmeimei" 在數(shù)組尾部添加一個(gè)新元素
刪除元素:
unset array[2] 清空元素
unset array 清空整個(gè)數(shù)組
分片訪問(wèn):
${array[@]:1:4} 顯示數(shù)組下標(biāo)索引從1開(kāi)始到3的3個(gè)元素
內(nèi)容替換:
${array[@]/an/AN} 將數(shù)組中所有元素包含an的子串替換為AN
數(shù)組遍歷:
for v in ${array[@]}
do
echo $v
done
declare -x 將變量聲明為環(huán)境變量
test1.sh
運(yùn)行 shtest1.sh
當(dāng)使用declare -x 變量后,就可以直接在腳本中引用了
到此這篇關(guān)于詳解shell 變量的高級(jí)用法示例的文章就介紹到這了,更多相關(guān)shell 變量用法內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!