主頁(yè) > 知識(shí)庫(kù) > 詳解shell 變量的高級(jí)用法示例

詳解shell 變量的高級(jí)用法示例

熱門標(biāo)簽:Linux服務(wù)器 鐵路電話系統(tǒng) 地方門戶網(wǎng)站 呼叫中心市場(chǎng)需求 百度競(jìng)價(jià)排名 網(wǎng)站排名優(yōu)化 AI電銷 服務(wù)外包

變量刪除和替換

案例:從頭開始匹配,將符合最短的數(shù)據(jù)刪除 (#)

variable_1="I love you, Do you love me"
echo $variable_1
variable_2=${variable_1#*ov}
echo $variable_2

案例:從頭開始匹配,將復(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)單舉例(用的比較少)

var=${str-expr}

如果變量 str 沒有定義,那么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)度 (只能從頭開始匹配,用的不多)

例子:找不到返回 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開始一直到結(jié)尾的字符串,索引下標(biāo)從0開始

var1="kafka hadoop yarn mapreduce"
sub_str1=${var1:10}
echo $sub_str1

案例:方法二

從第10個(gè)位置開始提取5個(gè)字符串

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,索引計(jì)數(shù)是從1開始計(jì)算 使用${string:position},索引計(jì)數(shù)是從0開始

字符串處理完整腳本

需求描述:

變量 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)算,包括加減乘除,引用變量前面可以加$,也可以不加$

echo "$((20+30))"

示例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:

今天是今年的第多少天

echo $(date +%j)

根據(jù)系統(tǒng)時(shí)間獲取今年還剩下多少星期,已經(jīng)過了多少星期

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)程是否存在,如果沒有需求拉起這個(gè)進(jìn)程

example_3.sh

#!/bin/bash
#
# grep -v 過濾掉 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ù)組所有元素

echo ${array[@]}

列出其中指定的一個(gè)

echo ${array[1]}

計(jì)算數(shù)組長(zhǎng)度

echo ${#array[@]}

輸出數(shù)組中元素長(zhǎng)度

echo ${#array[0]}

-f 顯示此腳本前定義過的所有函數(shù)和內(nèi)容 ,-F 進(jìn)顯示腳本前定義過的函數(shù)名

declare -f
declare -F

數(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ù)組
 
分片訪問:
 ${array[@]:1:4}  顯示數(shù)組下標(biāo)索引從1開始到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

#!/bin/bash
#
 
echo $num5

運(yùn)行 shtest1.sh

當(dāng)使用declare -x 變量后,就可以直接在腳本中引用了

num5=30
declare -x num5

到此這篇關(guān)于詳解shell 變量的高級(jí)用法示例的文章就介紹到這了,更多相關(guān)shell 變量用法內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • Shell編程之變量的高級(jí)用法詳解

標(biāo)簽:衡水 黃山 崇左 銅川 湘潭 湖南 仙桃 蘭州

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《詳解shell 變量的高級(jí)用法示例》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266