shell腳本編程3

補充,shift使用方法

root@localhost wang]# cat jiaoben1.sh 
#!/bin/bash
echo "$1"
echo "$*"
shift
echo "$1"
echo "$*"
shift
echo "$1"
echo "$*"
shift 2
echo "$1"
echo "$*"
[root@localhost wang]# bash jioaben1.sh a b c d e f g 
a
a b c d e f g
b
b c d e f g
c
c d e f g
e
e f g

匿名函數{}

例:flase || { echo "xxx";exit }

十三、數組

    變量:存儲單個元素的內存空間

    數組:存儲多個元素的連續的內存空間,相當于多個變量的集合。

    數組名和索引

        索引:編號從0開始,屬于數值索引

        注意:索引可支持使用自定義的格式,而不僅是數值格式,即為關聯索引, bash4.0版本之后開始支持。

        bash的數組支持稀疏格式(索引不連續)

    定義數組

    聲明數組:

        declare -a ARRAY_NAME

        declare -A ARRAY_NAME: 關聯數組

        注:先聲明,在使用。

    數組元素的賦值:

        一次只賦值一個元素;

            ARRAY_NAME[INDEX]=VALUE

[root@localhost wang]# tom[1]=a
[root@localhost wang]# tom[2]=b
[root@localhost wang]# tom[3]=c
[root@localhost wang]# echo ${tom[*]}
a b c
[root@localhost wang]# echo ${tom[1]}
a
[root@localhost wang]# echo ${tom[2]}
b

        一次賦值全部元素:

            ARRAY_NAME=("VAL1" "VAL2" "VAL3" …)

[root@localhost wang]# jay=(q w e r d f)
[root@localhost wang]# echo ${jay[*]}
q w e r d f
[root@localhost wang]# echo ${jay}
q
[root@localhost wang]# echo ${jay[1]}
w
[root@localhost wang]# echo ${jay[2]}
e

        只賦值特定元素:

            ARRAY_NAME=([0]="VAL1" [3]="VAL2" …)

[root@localhost wang]# ban=([1]=one [2]=two [3]=three)
[root@localhost wang]# echo ${ban[*]}
one two three
[root@localhost wang]# echo ${ban[1]}
one
[root@localhost wang]# echo ${ban[2]}
two

        交互式數組值對賦值

            read -a ARRAY

    引用數組

    引用數組元素: ${ARRAY_NAME[INDEX]}

        注意:省略[INDEX]表示引用下標為0的元素

    數組的長度(數組中元素的個數):

        ${#ARRAY_NAME[*]}

        ${#ARRAY_NAME[@]}

[root@localhost wang]# echo ${jan[*]}
a bc def ghij klmno pqrst uvwxyz
[root@localhost wang]# echo ${#jan[*]}
7
[root@localhost wang]# echo ${jan}
a
[root@localhost wang]# echo ${#jan}
1
[root@localhost wang]# echo ${jan[2]}
def
[root@localhost wang]# echo ${#jan[2]}
3

    示例:生成10個隨機數保存于數組中,并找出其最大值和最小值

[root@localhost sh.log]# cat declareminmax.sh 
#!/bin/bash
#author:DYW
#生成10個隨機數,取最大最小值。
declare -a zu
declare -i min
declare -i max
for a in {0..9};do
	zu[$a]=$RANDOM
	[ $a -eq 0 ]&& { min=${zu[$a]};max=${zu[$a]}; }
	[ $min -gt ${zu[$a]} ] && min=${zu[$a]}
	[ $max -lt ${zu[$a]} ] && max=${zu[$a]}
done
echo "all number are ${zu[*]}"
echo "max:$max min:$min"
[root@localhost sh.log]# bash declareminmax.sh 
all number are 12445 5069 3252 2204 16619 2817 9614 7954 25200 17136
max:25200 min:2204

    數組數據處理

    引用數組中的元素:

        所有元素: ${ARRAY[@]}, ${ARRAY[*]}

        數組切片: ${ARRAY[@]:offset:number}

            offset: 要跳過的元素個數

            number: 要取出的元素個數

            取偏移量之后的所有元素

                {ARRAY[@]:offset}

[root@localhost wang]# echo ${jan[*]}
a bc def ghij klmno pqrst uvwxyz
[root@localhost wang]# echo ${jan[*]:2:3}
def ghij klmno
[root@localhost wang]# echo ${jan[*]:2}
def ghij klmno pqrst uvwxyz

    向數組中追加元素:

        ARRAY[${#ARRAY[*]}]

    刪除數組中的某元素:導致稀疏格式

        unset ARRAY[INDEX]

    關聯數組:

        declare -A ARRAY_NAME

        ARRAY_NAME=([idx_name1]=('val1' [idx_name2]='val2‘…)

十四、字符串處理

bash的字符串處理工具:

字符串切片:

${#var}:返回字符串變量var的長度

${var:offset}:返回字符串變量var中從第offset個字符后(不包括第offset個字符)的字符開始,到最后的部分,offset的取值在0 到 ${#var}-1 之間

${var:offset:number}:返回字符串變量var中從第offset個字符后(不包括第offset個字符)的字符開始,長度為number的部分

${var: -lengh}:取字符串的最右側幾個字符:

注意:冒號后必須有一空白字符

[root@localhost ~]# echo $var
abcdefghijklmnopqrstuvwxyz
[root@localhost ~]# echo ${var:3}
defghijklmnopqrstuvwxyz
[root@localhost ~]# echo ${var:3:5}
defgh
[root@localhost ~]# echo ${var: -3}
xyz
[root@localhost ~]# echo ${var:3: -3}
defghijklmnopqrstuvw
[root@localhost ~]# echo ${var:3: -3}

    基于模式取子串:

        ${var#*word}:其中word可以是指定的任意字符

            功能:自左而右,查找var變量所存儲的字符串中,第一次出現的word, 刪除字符串開頭至第一次出現word字符之間的所有字符

        ${var##*word}:同上,不同的是,刪除的是字符串開頭至最后一次由word指定的字符之間的所有內容

            file="/var/log/messages"

            ${file##*/}: messages

        ${var%word*}:其中word可以是指定的任意字符;

            功能:自右而左,查找var變量所存儲的字符串中,第一次出現的word, 刪除字符串最后一個字符向左至第一次出現word字符之間的所有字符;

                file="/var/log/messages"

                ${file%/*}: /var/log

        ${var%%word*}:同上,只不過刪除字符串最右側的字符向左至最后一次出現word字符之間的所有字符;

[root@localhost ~]# echo $var
root:x:0:0:root,,62985600:/root:/bin/bash
[root@localhost ~]# echo ${var#*root}
:x:0:0:root,,62985600:/root:/bin/bash
[root@localhost ~]# echo ${var##*root}
:/bin/bash
[root@localhost ~]# echo ${var%:*}
root:x:0:0:root,,62985600:/root
[root@localhost ~]# echo ${var%%:*}
root

    查找替換:

        ${var/pattern/substi}:查找var所表示的字符串中,第一次被pattern所匹配到的字符串,以substi替換之

        ${var//pattern/substi}: 查找var所表示的字符串中,所有能被pattern所匹配到的字符串,以substi替換之

        ${var/#pattern/substi}:查找var所表示的字符串中,行首被pattern所匹配到的字符串,以substi替換之

        ${var/%pattern/substi}:查找var所表示的字符串中,行尾被pattern所匹配到的字符串,以substi替換之

[root@localhost ~]# echo $var
root:x:0:0:root,,62985600:/root:/bin/bash
[root@localhost ~]# echo ${var/root/laowang}
laowang:x:0:0:root,,62985600:/root:/bin/bash
[root@localhost ~]# echo ${var//root/laowang}
laowang:x:0:0:laowang,,62985600:/laowang:/bin/bash
[root@localhost ~]# echo ${var/#root/laowang}
laowang:x:0:0:root,,62985600:/root:/bin/bash
[root@localhost ~]# echo ${var/%bash/laowang}
root:x:0:0:root,,62985600:/root:/bin/laowang

    查找并刪除:

        ${var/pattern}:查找var所表示的字符串中,刪除第一次被pattern所匹配到的字符串

        ${var//pattern}:所有

        ${var/#pattern}:首行

        ${var/%pattern}:行尾

    字符大小寫轉換:

        ${var^^}:把var中的所有小寫字母轉換為大寫

        ${var,,}:把var中的所有大寫字母轉換為小寫

    變量賦值

        ${var:-value}:如果var為空或未設置,那么返回value;否則,則返回var的值

[root@localhost ~]# var=laowang
[root@localhost ~]# echo ${var:-mage}
laowang
[root@localhost ~]# unset var
[root@localhost ~]# echo ${var:-mage}
mage

        ${var:+value}:如果var不空,則返回value

[root@localhost ~]# var=laowang
[root@localhost ~]# echo ${var:+mage}
mage
[root@localhost ~]# unset var
[root@localhost ~]# echo ${var:+mage}

        ${var:=value}:如果var為空或未設置,那么返回value,并將value賦值給var;否則,則返回var的值

[root@localhost ~]# echo ${var:=mage}
laowang
[root@localhost ~]# unset var
[root@localhost ~]# echo ${var:=mage}
mage

        ${var:?error_info}:如果var為空或未設置,那么返回error_info;否則,則返回var的值為腳本程序使用配置文件,實現變量賦值

[root@localhost ~]# var=laowang
[root@localhost ~]# echo ${var:?mage}
laowang
[root@localhost ~]# unset var
[root@localhost ~]# echo ${var:?var is empty}
-bash: var: var is empty

    定義文本文件,每行定義“ name=value”

    在腳本中source此文件即可

    高級變量用法-有類型變量

    Shell變量一般是無類型的,但是bash Shell提供了declare和typeset兩個命令用于指定變量的類型,兩個命令是完全等價的

    declare [選項] 變量名

        -r 將變量設置為只讀屬性

        -i 將變量定義為整型數

        -a 將變量定義為數組

        -A 將變量定義為關聯數組

        -f 顯示此腳本前定義過的所有函數名及其內容

        -F 僅顯示此腳本前定義過的所有函數名

        -x 將變量聲明為環境變量

        -l 將變量值轉為小寫字母

        -u 將變量值轉為大寫字母

    間接變量引用

    如果第一個變量的值是第二個變量的名字,從第一個變量引用第二個變量的值就稱為間接變量引用

    variable1=variable2

    variable2=value

    variable1的值是variable2,而variable2又是變量名,variable2的值為value,間接變量引用是指通過variable1獲得變量值value的行為

    bash Shell提供了兩種格式實現間接變量引用

    eval tempvar=\$$variable1

[root@localhost ~]# v1=v2
[root@localhost ~]# v2=wang
[root@localhost ~]# ecal v3=\$$v1
-bash: ecal: command not found
[root@localhost ~]# eval v3=\$$v1
[root@localhost ~]# echo $v3
wang

    tempvar=${!variable1}

[root@localhost ~]# v1=v2
[root@localhost ~]# v2=wang
[root@localhost ~]# v3=${!v1}
[root@localhost ~]# echo $v3
wang

eval命令

    eval命令將會首先掃描命令行進行所有的置換,然后再執行該命令。該命令適用于那些一次掃描無法實現其功能的變量。該命令對變量進行兩次掃描。

[root@localhost ~]# cmd=pwd
[root@localhost ~]# echo $cmd
pwd
[root@localhost ~]# eval $cmd
/root

創建臨時文件

    mktemp命令:創建的臨時文件可避免沖突

    mktemp [OPTION]… [TEMPLATE]

        TEMPLATE: filename.XXX

        X至少要出現三個

    OPTION:

        -d: 創建臨時目錄

        -p dir或–tmpdir=/DIR:指明臨時文件所存放的目錄位置

[root@localhost wang]# mktemp file.XXX
file.MCe
[root@localhost wang]# a=`mktemp file.XXX`
[root@localhost wang]# echo $a
file.4P8

    安裝復制文件

    install命令:

        install [OPTION]… [-T] SOURCE DEST 單文件

        install [OPTION]… SOURCE… DIRECTORY

        install [OPTION]… -t DIRECTORY SOURCE…

        install [OPTION]… -d DIRECTORY…創建空目錄

    選項:

        -m MODE,默認755

        -o OWNER

        -g GROUP

        -d 創建目錄

    bash如何展開命令行

        把命令行分成單個命令詞

        展開別名

        展開大括號種的聲明( {})

        展開波浪符聲明( ~)

        命令替換$() 和 “)

        再次把命令行分成命令詞

        展開文件通配( *、 ?、 [abc]等等)

        準備I/0重導向( <、 >)

        運行命令

        

    防止擴展

        反斜線( \)會使隨后的字符按原意解釋

            $ echo Your cost: \$5.00

            Your cost: $5.00

        加引號來防止擴展

            單引號( ’)防止所有擴展

            雙引號( ”)也防止所有擴展,但是以下情況例外:

            ↘$(美元符號) - 變量擴展

            ↘`(反引號) - 命令替換

            ↘\(反斜線) - 禁止單個字符擴展

            ↘!(嘆號) - 歷史命令替換

    bash的配置文件

        按生效范圍劃分,存在兩類:

        全局配置:

            /etc/profile

            /etc/profile.d/*.sh

            /etc/bashrc

        個人配置:

            ~/.bash_profile

            ~/.bashrc

    shell登錄兩種方式

        交互式登錄:

            直接通過終端輸入賬號密碼登錄;

            使用“ su – UserName” 切換的用戶

        執行順序:

            /etc/profile –> /etc/profile.d/*.sh –> ~/.bash_profile –> ~/.bashrc –> /etc/bashrc

        非交互式登錄:

            su UserName

            圖形界面下打開的終端

            執行腳本

        執行順序:

            ~/.bashrc –> /etc/bashrc –> /etc/profile.d/*.sh

    Profile類

        按功能劃分,存在兩類:

            profiile類和bashrc類

        profile類:為交互式登錄的shell提供配置

            全局: /etc/profile, /etc/profile.d/*.sh

            個人: ~/.bash_profile

            功用:

            用于定義環境變量

            運行命令或腳本

    Bashrc類

        bashrc類:為非交互式和交互式登錄的shell提供配置

            全局: /etc/bashrc

            個人: ~/.bashrc

            功用:

                定義命令別名和函數

                定義本地變量

    編輯配置文件生效

        修改profile和bashrc文件后需生效

            兩種方法:

                重新啟動shell進程

                . 或source

        例:

            . ~/.bashrc

    Bash 退出任務

        保存在~/.bash_logout文件中(用戶)

        在退出登錄shell時運行

        用于

        創建自動備份

        清除臨時文件

原創文章,作者:DYW,如若轉載,請注明出處:http://www.www58058.com/39617

(0)
DYWDYW
上一篇 2016-08-24 21:23
下一篇 2016-08-24 22:10

相關推薦

  • Linux網絡相關概念及bash腳本編程練習

    馬哥教育網絡班第23期+第八周課堂練習 Linux網絡相關概念及bash腳本編程練習 習題: 1.請描述網橋、集線器、二層交換機、三層交換機、路由器的功能、使用場景與區別 (1)網橋: 橋接器(英語:network bridge),又稱網橋,一種網路裝置,負責網路橋接(network bridging)之用。 橋接器將網絡的多個網段在數據鏈路層(O…

    Linux干貨 2016-11-15
  • grep與正則表達式

    文本處理中比較強悍的三個工具是:grep、sed、awk。 其中grep主要作用是對于用戶給出“模式”對文本逐行進行匹配檢查,然后進行打印。   模式:由正則表達式字符及文本字符編寫的過濾條件 格式:grep [選項] [正則表達式字符]  文件  常用的選項:     -v:反向查找,顯示沒有被匹配的的行 …

    Linux干貨 2016-08-08
  • Linux grep與正則表達式淺析

    #Linux grep與正則表達式淺析 ##grep   grep(global search regular expression(RE) and print out the line,全面搜索正則表達式并把行打印出來)是一種強大的文本搜索工具,它能使用正則表達式搜索文本,并把匹配的行打印出來。 ###grep語法    &n…

    Linux干貨 2017-04-06
  • grep及正則表達式相關練習

    grep及正則表達式相關練習 1、復制/etc/skel目錄為/home/tuser1,要求/home/tuser1及其內部文件的屬組和其它用戶均沒有任何訪問權限。 ~]# cp -r /etc/skel/ /home/tuser1 ~]# chmod -R 700 /home/tuser1 ~]# ls -ld /home/tuser1 drwx&#821…

    Linux干貨 2016-10-11
  • vsftpd虛擬用戶搭建

    首選的FTP服務器搭建方式 安裝vsftpd      yum install -y vsftpd      systemctl enable vsftpd     #設置開機啟動      systemctl is-enabled vsf…

    Linux干貨 2017-04-27
  • linux系統啟動流程

    linux系統啟動流程 CentOS(5、6)系統啟動流程 具體流程: 加載BIOS的硬件信息與進行自我測試,并依據設置取得第一個可啟動的設備; 讀取并執行第一個啟動設備內MBR的boot Loader 依據boot Loader的設置加載Kernel,Kernel會開始檢測硬件與加載驅動程序 硬件驅動成功后,Kernel會主動調用init進程,而init會…

    Linux干貨 2016-09-11
欧美性久久久久