Linux bash總結(一) 基礎部分(適合初學者學習和非初學者參考)


 

早上起來,外面的雨下的稀里嘩啦……本來事先約定好的朋友聚餐也因此取消了。
心想,閑着也是閑着,不如將自己所學的bash腳本知識梳理一遍。一來,可以給bash初學者提供一個學習平台;再者,非初學者書寫腳本時,也能以此為參考。若您在閱讀時,文章能給您一點點啟發,那我的目的就達到了。

花了3天功夫,終於整理完畢了。可能還有許多需要完善的地方,希望讀者能給出寶貴的意見!鑒於文章內容比較多,下面先介紹一下主要內容。

第一部分 bash簡介
    —— 對bash進行簡要介紹
第二部分 bash示例和書寫流程
    —— 以一個簡單的bash為例,說明書寫、執行bash的流程
第三部分 bash基礎語法
   —— 本章內容比較多,主要介紹if...else...條件判斷,for循環等等。對於有編程基礎的朋友來說應該很容易,沒有編程基礎也沒關系;參考文章中的實例,應該很容易就能掌握本章知識。
第四部分 bash數組
   —— 介紹bash數組的定義和相關操作
第五部分 函數
   —— 介紹bash函數的定義及調用方法
第六部分 數值運算
   —— 介紹+、-、*、/等操作
第七部分 字符運算
   —— 介紹字符串操作
第八部分 bash自帶參數
   —— 說明bash中自帶的參數,它們在編寫bash腳本時中經常會被用到。
第九部分 bash調試
   —— 說明bash常用的調試方法
第十部分 bash注釋
   —— 說明bash中添加單行注釋以及區域注釋的常用方法
第十一部分 bash內建指令
   —— 介紹bash中常用的內建命令
第十二部分 bash實例
   —— 以一個實例來總結基礎部分

 

第一部分 bash簡介

在介紹bash之前,需要先介紹它的起源——shell。shell俗稱殼,它是指UNIX系統下的一個命令解析器;主要用於用戶和系統的交互。UNIX系統上有很多種Shell。首個shell,即Bourne Shell,於1978年在V7(AT&T的第7版)UNIX上推出。后來,又演變出C shell、bash等不同版本的shell。
bash,全稱為Bourne-Again Shell。它是一個為GNU項目編寫的Unix shell。bash腳本功能非常強大,尤其是在處理自動循環或大的任務方面可節省大量的時間。bash是許多Linux平台的內定Shell,這也是我們介紹它主要的原因。

 

第二部分 bash示例和書寫流程

1 新建文件test.sh

$ touch test.sh

2 添加可執行權限

$ chmod +x test.sh

3 編輯test.sh,test.sh內容如下:

#!/bin/bash echo "hello bash" exit 0

說明:
#!/bin/bash : 它是bash文件聲明語句,表示是以/bin/bash程序執行該文件。它必須寫在文件的第一行!
echo "hello bash" : 表示在終端輸出“hello bash”
exit 0 : 表示返回0。在bash中,0表示執行成功,其他表示失敗。
4 執行bash腳本

$ ./bash

在終端輸出“bash hello”

 

 

第三部分 bash基礎語法

1 條件判斷

條件判斷有2中格式,分別是“test EXPRESSION”和“[ EXPRESSION ]”。
“test”判斷語句,在實際中應用的比較少;相反的,“[]”判斷語句應用很廣。下面分別對它們進行介紹

1.1 test判斷語句

基本格式

test EXPRESSION

格式說明

test是關鍵字,表示判斷;
EXPRESSION是被判斷的語句。
關於EXPRESSION的說明,參考如下:

應用實例

一、判斷文件/home/skywang/123.txt是不是文件

$ test -f /home/skywang/123.txt

其他說明

在linux系統下,可以通過以下命令去測試上面的實例
# 切換到執行目錄(如切換到/home/skywang)

$ cd /home/skywang

# 判斷123.txt是不是文件

$ test -f 123.txt

# 輸出判斷結果,0表示成功,其他表示失敗。
# 其中,echo表示輸出文本到當前終端,$?表示上一命令的執行結果(在linux中bash中,命令成功返回0,失敗返回其他)。

$ echo $?


1.2 []條件判斷

基本格式

[ EXPRESSION ]

格式說明
中括號的左右擴弧和EXPRESSION之間都必須有空格!
關於EXPRESSION的說明,參考如下:

應用實例
一、判斷文件/home/skywang/123.txt是否存在

$ [ -f /home/skywang/123.txt ]

二、判斷變量val是否等於字符串“skywang”

$ [ "$val" = "skywang" ]

三,判斷變量num是否等於數字100

$ [ "$num" -eq "100" ]


1.3 測試邏輯表達式

基本格式
-a : 邏輯與,操作符兩邊均為真,結果為真,否則為假。
-o : 邏輯或,操作符兩邊一邊為真,結果為真,否則為假。
! : 邏輯否,條件為假,結果為真。
應用實例
一、判斷文件123.txt是不是可讀寫

$ [ -r 123.txt -a -w 123.txt ]

等價於

$ [ -r 123.txt ] && [ -w 123.txt ]

二、判斷變量num是不是等於數字101或102

$ [ "$num" -eq "101" -o "$num" -eq "102" ]

等價於

$ [ -r 123.txt ] || [ -w 123.txt ]

三、判斷文件123.txt是不是不可讀

$ [ ! -r 123.txt ]

2 if then else語句

基本格式
if 條件1
then 命令1
elif 條件2
then 命令2
else 命令3
if
格式說明
if 語句必須以單詞 fi 終止。elif 和 else 為可選項,如果語句中沒有否則部分,那么就不需要 elif 和 else 部分。if 語句可以有許多 elif 部分。最常用的 if 語句是 if then fi 結構。
應用實例
一、判斷文件文件123.txt是否存在,存在則輸出“file exist”;沒有則輸出“file not exist”。bash文件內容如下:

#!/bin/bash if [ -f 123.txt ];then
echo "file exist"
else
echo "file not exist"
fi exit 0

二、提示用戶輸入值。若輸入的值小於0,則輸出“negtive number”;若等於0,則輸出“number zero”,否則,輸出“positive number”。bash文件內容如下:

#!/bin/bash # 提示用戶輸入一個值 echo -n "please input a number:" # 保存用戶輸入的值到num中 read num if [ "$num" -lt "0" ];then # 小於0,則輸出“negtive number” echo "negtive number" 
elif [ "$num" -gt "0" ];then # 大於0,則輸出“positive number” echo "positive number" 
else # 大於0,則輸出"number zero" 
echo "number zero"
fi exit 0

3 case語句

case語句為多選擇語句。可以用case語句匹配一個值與一個模式,如果匹配成功,執行相匹配的命令。
基本格式
case 值 in
模式1}
命令1
...
;;
模式2)
命令2
...
;;
esac
格式說明
“模式”部分可能包括元字符,即:
* 任意字符。
? 任意單字符。
[..] 類或范圍中任意字符
應用實例
一、提示用戶輸入Y/y或N/n。若輸入Y/y,則輸出“yes”;若輸入N/n,則輸出“no”;否則,“incorrect input”。bash文件內容如下:

#!/bin/bash # 提示用戶輸入一個值 echo -n "are you femail(Y/N):" # 保存用戶輸入的值到val中 read val case $val in Y|y) # 用戶輸入Y或y echo "yes" ;; N|n) # 用戶輸入N或n "no" ;; *) # 其它輸入 echo "incorrect input" ;; esac exit 0

 

4 for循環

基本格式
for 變量名in列表
do
命令1
命令2...
done
格式說明
當變量值在列表里, for循環即執行一次所有命令,使用變量名訪問列表中取值。命令可為任何有效的 shell命令和語句。變量名為任何單詞。 in列表用法是可選的,如果不用它, for循環使用命
令行的位置參數。
應用實例
一、輸入當前文件夾的一級子目錄中文件名字。bash腳本內容如下:

#!/bin/bash # 將ls的結果保存到變量CUR_DIR中 CUR_DIR=`ls` # 顯示ls的結果 echo $CUR_DIR for val in $CUR_DIR do # 若val是文件,則輸出該文件名 if [ -f $val ];then
echo "FILE: $val"
fi 
done exit 0

 

二、輸出1-10之間數字的總和。bash腳本內容如下:

#!/bin/bash sum=0
for ((i=1;i<10;i++)) do ((sum=$sum+$i)) done 

echo "sum=$sum" exit 0

  

5 until循環

until循環執行一系列命令直至條件為真時停止。until循環與 while循環在處理方式上剛好相反。一般 while循環優於until循環,但在某些時候 — 也只是極少數情況下, until循環更加有用。
基本格式
until 條件
命令1
...
done
格式說明
條件可為任意測試條件,測試發生在循環末尾,因此循環至少執行一次 — 請注意這一點。
應用實例
一、從0開始逐步遞增,當數值等於5時,停止遞增。Bash腳本內容如下:

#!/bin/bash # 設置起始值為0 val=0

until [ "$val" -eq "5" ] do # 輸出數值 echo "val=$val" # 將數值加1 ((val++)) done exit 0

 

6 while循環

基本格式
while 命令
do
命令1
命令2
...
done
應用實例
一、從0開始逐步遞增,當數值等於5時,停止遞增。Bash腳本內容如下:

#!/bin/bash # 設置起始值為0 val=0

while [ "$val" -lt "5" ] do # 輸出數值 echo "val=$val" # 將數值加1 ((val++)) done exit 0


7 使用break和continue控制循環

基本格式
break命令允許跳出循環。
continue命令類似於 break命令,只有一點重要差別,它不會跳出循環,只是跳過這個循環步。
應用實例
一、[break應用]從0開始逐步遞增,當數值等於5時,停止遞增。Bash腳本內容如下:

#!/bin/bash # 設置起始值為0 val=0

while true
do
if [ "$val" -eq "5" ];then # 如果val=5,則跳出循環 break; else # 輸出數值 echo "val=$val" # 將數值加1 ((val++)) fi 
done exit 0

 

二、[continue應用]從0開始逐步遞增到10:當數值為5時,將數值遞增2;否則,輸出數值。Bash腳本內容如下:

#!/bin/bash # 設置起始值為0 val=0

while [ "$val" -le "10" ] do
if [ "$val" -eq "5" ];then # 如果val=5,則將數值加2 ((val=$val+2)) continue; else # 輸出數值 echo "val=$val" # 將數值加1 ((val++)) fi 
done exit 0

 

第四部分 bash數組

1 數組定義

1. array=(10 20 30 40 50)
一對括號表示是數組,數組元素用“空格”符號分割開。引用數組時從序號0開始。

2. 除了上面的定義方式外,也可以單獨定義數組:
array[0]=10
array[1]=20
array[2]=30
array[3]=40
array[4]=50

3. var="10 20 30 40 50"; array=($var)


2 數組操作

(01) 顯示數組中第2項

$ echo ${array[i]} 說明:數組是從序號0開始計算(即第1項為array[0])。

(02) 顯示數組中的所有元素

$ echo ${array[@]} 或者 $ echo ${array[*]}

(03) 顯示數組長度

$ echo ${#array[@]} 或者 $ echo ${#array[*]}

(04) 刪除數組第2項元素

$ unset array[1] 說明: unset僅僅只清除array[1]的值,並沒有將array[1]刪除掉

(05) 刪除整個數組

$ unset array

(06) 輸出數組的第1-3項

$ echo ${array[@]:0:3} 說明: 參考“${數組名[@或*]:起始位置:長度}”

(07) 將數組中的0替換成1

$ echo ${a[@]/0/1} 說明: ${數組名[@或*]/查找字符/替換字符

 

第五部分 函數

1 函數定義

基本格式
function 函數名()
{
...
}

格式說明
function可有可無。但建議保留,因為保留的話看起來更加直觀。

應用實例

function foo()
{
    # 定義局部變量i
    local i=0 
    # 定義局部變量total=傳入foo的參數總數
    local total=$#
    # 輸出參數總數
    echo "total param =$total"
    # 輸出傳入foo的每一個參數
    for val in $@
    do  
        ((i++))
        echo "$i -- val=$val"
    done

    # 返回參數總數
    return $total
}

2 函數調用和傳參

調用方法

直接通過函數名去調用。

應用實例

foo param1 param2 param3

說明:

調用函數foo,並傳入param1 param2 param3三個參數

3 函數返回值

使用方法

return 返回值

方法說明

例如,foo param1 param2 param3之后,再調用$?就是上次調用的返回值

 

4 應用實例

編輯一個函數foo:打印foo的輸入參數的總數,並輸入每個參數和參數對應的序號。

#!/bin/bash function foo() { # 定義局部變量i local i=0 # 定義局部變量total=傳入foo的參數總數 local total=$# # 輸出參數總數 echo "total param =$total" # 輸出傳入foo的每一個參數 for val in $@ do ((i++)) echo "$i -- val=$val"
    done # 返回參數總數 return $total } foo foo param1 param2 param3 # 輸出foo param1 param2 param3的返回值 echo "return value=$?" exit 0

 

輸出結果:

total param =0 total param =3
1 -- val=param1 2 -- val=param2 3 -- val=param3 return value=3

 

第六部分 數值運算

數值比較請參考"第三部分"的1.2節,本部分只介紹數值運算。

常用的4種數值運算說明
數值元算主要有4種實現方式:(())、let、expr、bc。
工作效率:
(()) == let > expr > bc
(01), (())和let是bash內建命令,執行效率高;而expr和bc是系統命令,會消耗內存,執行效率低。
(02), (())、let和expr只支持整數運算,不支持浮點運算;而bc支持浮點運算。

下面分別介紹這4種實現方式的使用方法。
應用實例一:分別用上面四種方式實現"3*(5+2)"。

#!/bin/bash # 數值i=3*(5+2) (方法一:$(())實現) val=$((3*(5+2))) echo "val=$val" # 數值i=3*(5+2) (方法二:let實現) let "val=3*(5+2)"
echo "val=$val" # 數值i=3*(5+2) (方法三:expr實現) val=`expr 3 \* \( 5 + 2 \)` echo "val=$val" # 數值i=3*(5+2) (方法四:bc實現) val=`echo "3*(5+2)"|bc` echo "val=$val" exit 0

應用實例二:分別勇上面四種方式實現“數值+1”。

#!/bin/bash val=0 # 數值加1 (方法一) ((val++)) echo "val=$val" val=0 # 數值加1 (方法二) let val++
echo "val=$val" val=0 # 數值加1 (方法三) val=`expr $val + 1` echo "val=$val" val=0 # 數值加1(方法四) val=`echo "$val+1"|bc` echo "val=$val" exit 0

應用實例三:計算1/3,保留3位小數。

#!/bin/bash # 數值i=3*(5+2) (方法四:bc實現) val=`echo "scale=3; 1/3"|bc` echo "val=$val" exit 0

 

第七部分 字符運算

1 字符串定義

 

2 字符串操作

2.1 string操作公式表

2.2 應用實例

首先,我們定義個str字符串變量,然后再對此變量進行字符串操作。

$ str="hello world"

(01) 顯示字符串長度

$ echo ${#str}

(02) 提取world

$ echo ${str:6}

(03) 提取or

$ echo ${str:7:2}

(04) 刪除hello

$ echo ${str#hello} 或 $ echo ${str#*lo}

(05) 刪除world

$ echo ${str%world}$ echo ${str%wo*}

(06) 將所有的字符“l”替換為“m”

$ echo ${str//l/m}

 

第八部分 bash自帶參數

 

第九部分 bash調試

1 bash命令調試

bash [-nvx] scripts.sh
選項與參數:
-n :不要執行 script,僅查詢語法的問題;
-v :再執行 sccript 前,先將 scripts 的內容輸出到屏幕上;
-x :將使用到的 script 內容顯示到屏幕上,這是很有用的參數!
例如,想要執行bash腳本,並查看bash的調用流程,可以通過以下命令:

$ bash -x test.sh

2 echo調試
echo [OPTION] STRING
-n : 輸出內容之后,不換行。默認是輸入內容之后,換行。
-e : 開啟反斜線“\”轉義功能
-E : 開啟反斜線“\”轉義功能(默認)。
例如,輸出“please input a number:”之后不換行。

$ echo -n "please input a number:"

3 printf
和echo一樣,printf也能用於輸出。語法格式和C語言中printf一樣。
例如,輸出“hello printf”之后換行。

$ printf "hello printf\n"

 

第十部分 bash注釋

1 單行注釋

# echo "single line"
說明:#放在文件開頭,表示注釋掉本行。

2 多行注釋

可以通過以下兩種方法實現多行注釋:

:||{ ....被注釋的多行內容 }

或者

if false ; then ....被注釋的多行內容 fi

 

第十一部分 bash內建指令

1 內建命令查看方法

基本格式
type cmd
格式說明
type是命令關鍵字,cmd表示查看的命令;若輸出builtin,則該命令是bash的內建命令。
例如:

$ type echo

除此之外,用戶也可以通過man bash或者man builtins查看bash的全部內置命令.

2 常用內建命令說明

(01)echo
命令:echo arg
功能:在屏幕上顯示出由arg指定的字串
(02)read
命令格式:read變量名表
功能:從標准輸入設備讀入一行,分解成若干字,賦值給bash程序內部定義的變量
(03)shift
命令:shift [N] (N為大於0的整數;當N省略時,等價與於“shift 1”)
功能:所有的參數依次向左移動N個位置,並使用$#減少N,直到$#=0為止。
(04)alias
命令:alias name='value'
功能:別名。用name替換value,value要用單引號括住。
(05)export
命令:export變量名[=變量值]
功能:export可以把bash的變量向下帶入子bash(即子bash中可以使用父bash的變量),從而讓子進程繼承父進程中的環境變量。但子bash不能用export把它的變量向上帶入父bash。
(06)readonly
命令:readonly 變量名
功能:定義只讀變量。不帶任何參數的readonly命令將顯示出所有只讀變量。
(07)exec
命令:exec 命令參數
功能:當bash執行到exec語句時,不會去創建新的子進程,而是轉去執行指定的命令,當指定的命令執行完時,該進程(也就是最初的bash)就終止了,所以bash程序中exec后面的語句將不再
被執行。
(08)"."(點)
命令:. bash程序文件名
功能:使bash讀入指定的bash程序文件並依次執行文件中的所有語句。
(09)exit
命令:exit N
功能:退出Shell程序。在exit之后可有選擇地指定一個數位作為返回狀態。

 

第十二部分 bash實例

實例一:備份/更新文件的腳本
01, 編寫一個腳本文件backup.sh,備份android、kernel或uboot中的文件,備份的時候要保留文件在備份文件夾(即保留文件的相對路徑)。
(01) 新建list_file.txt,並在list_file.txt中記錄要備份的文件的路徑。
(02) 當執行“./backup.sh bb”命令時:backup.sh會新建bb目錄,然后讀取list_file.txt中記錄的文件路徑,並將記錄的文件路徑對應的文件備份到bb目錄下。
(03) 當執行“./backup.sh tt”命令時,backup.sh會判斷是否存在tt目錄,若存在tt目錄的話,則tt中的文件更新到list_file.txt所記錄的文件路徑;否則的話,不更新文件。

腳本內容如下:

 

#!/bin/bash

##############################NOTE############################
#
# AUTHOR      : skyWang
# DATE        : 2012-07-16
# DESCRIPTION : 用於備份文件 or 更新文件
#
#               1. 備份文件
#               (1) 備份命令        :  ./run.sh bb
#               (2) 備份文件所在目錄:  bb
#                   這個是在步驟(1)之后,在當前目錄下自動建立bb目錄
#              
#               2. 更新文件
#               (1) 更新命令        :  ./run.sh tt
#               (2) 更新文件所在目錄:  tt
#                   這個是必須在步驟(1)之前已經存在的目錄。因為,就是為了用tt目錄中的文件去替換到目標文件。
#
# OTHER       : 1. list_file.txt 文件說明(即,list_file.txt中的文件必須滿足一下條件):
#               “變量COMMPATH_PATH的值”和“list_file.txt中的每一行內容”組合起來得到的完整路徑所對應的文件,必須存在!
#
#               例如: COMMON_PATH=/root/
#                      list_file.txt中有以下1行內容:
#                      android/build/core/Makefile
#               這樣,“變量COMMPATH_PATH的值”和“list_file.txt中的行”組合起來得到的完整路徑就是:
#                      /root/android/build/core/Makefile
#
#                “/root/android/build/core/Makefile”這個文件必須存在於電腦中。
#
#               (1)若list_file.txt滿足以上條件,運行“./run.sh bb”就可以備份“/root/android/build/core/Makefile”。
#                    備份時,會自動(在當前目錄下)建立目錄“bb”,並將文件備份到“bb”目錄下
#               (2)若將bb目錄重命名成tt,運行“./run.sh tt”就可以將“tt”中的文件更新到“/root/android/build/core/Makefile”。
#               
#
##############################NOTE############################


#########TODO...START#########
# 假設android、kernel、uboot在同一級目錄;
# 則,COMMON_PATH是它們所在目錄的路徑。
COMMON_PATH=/home/skywang/a8/gingerbread/code/
#########TODO...END###########


#########CONSTANT...START#########
LIST_FILE="list_file.txt"
B_FOLDER="bb/"
T_FOLDER="tt/"
# android工程的文件夾名字
ANDROID_FOLDER="android"
# kernel工程的文件夾名字
KERNEL_FOLDER="kernel"
# uboot工程的文件夾名字
UBOOT_FOLDER="uboot"
# android長度
ANDROID_FOLDER_LEN=`expr length "$ANDROID_FOLDER"`
# kernel長度
KERNEL_FOLDER_LEN=`expr length "$KERNEL_FOLDER"`
# uboot長度
UBOOT_FOLDER_LEN=`expr length "$UBOOT_FOLDER"`
#########CONSTANT...END###########


# 功能說明:根據源文件和目標文件所在完整路徑,將源文件更新到目標文件
#           更新成功的話,輸出更新的起止路徑;否則,打印錯誤信息
# 輸入參數:src_full_path    —— 源文件所在完整路徑。
#           dst_full_path    —— 目標文件所在完整路徑。
#           例如:src_full_path="tt/android/hardware/libsensor/sensors.cpp"
#                 dst_full_path="/home/skywang/mnt/sda6/a8/a72/3g/iceCreamSandwish/code/android/hardware/libsensor/sensors.cpp"
function func_update_file_by_path()
{
    local src_full_path=$1
    local dst_full_path=$2
    local dst_full_dir=`dirname $dst_full_path`

    if [ -f "$src_full_path" ];then
        if [ -e "$dst_full_path" ] || [ -d "$dst_full_dir" ];then
            cp -v $src_full_path $dst_full_path
        else
            mkdir -p $dst_full_dir
            cp -v $src_full_path $dst_full_path
        fi
    else
        echo copy file ERROR:
        echo file $src_full_path not existes!!!
    fi
}


# 功能說明:將“輸入文件”中全部文件全部更新到代碼中
#           更新成功的話,輸出更新的起止路徑;否則,打印錯誤信息
# 輸入參數:input_file    ——    “輸入文件”所在的完整路徑
#           例如:input_file="/home/skywang/mnt/sda6/a8/a72/3g/iceCreamSandwish/backup/exmaple/list_file.txt"
function func_push_files()
{
    local input_file=$1
    local full_path
    local backup_path
    local count=0

    while read -r line
    do
        let count=`expr $count + 1`
        if [ `expr match $line $ANDROID_FOLDER` == "$ANDROID_FOLDER_LEN" ] || 
           [ `expr match $line $KERNEL_FOLDER` == "$KERNEL_FOLDER_LEN" ] || 
           [ `expr match $line $UBOOT_FOLDER` == "$UBOOT_FOLDER_LEN" ];then
            echo "$count : right push path"
            src_path=${T_FOLDER}${line}
            dst_path=${COMMON_PATH}${line}
            func_update_file_by_path $src_path $dst_path
        else
            echo "$count : push file $line is invalidate!"
        fi
    done < $input_file

}


# 功能說明:根據源文件所在完整路徑,將源文件拷貝到另一個目錄下
#           備份成功的話,輸出備份的起止路徑;否則,打印錯誤信息
# 輸入參數:src_full_path    —— 源文件所在完整路徑。
#           dst_full_dir    —— 目標路徑
#           例如:src_full_path="/home/skywang/mnt/sda6/a8/a72/3g/iceCreamSandwish/code/android/hardware/libsensor/sensors.cpp"
#                 dst_full_dir="bb/android/hardware/libsensor/"
function func_backup_file_by_path()
{
    local src_full_path=$1
    local dst_full_dir=$2"/"

    if [ -f "$src_full_path" ];then
        if [ -d "$dst_full_dir" ];then
            cp -v $src_full_path $dst_full_dir
        else
            mkdir -p $dst_full_dir
            cp -v $src_full_path $dst_full_dir
        fi
    else
        echo backup file ERROR:
        echo file $src_full_path not existes!!!
    fi
}

# 功能說明:將“輸入文件”中全部文件全部做備份。
#           備份成功的話,輸出備份的起止路徑;否則,打印錯誤信息
# 輸入參數:input_file    ——    “輸入文件”所在的完整路徑
#           例如:input_file="/home/skywang/mnt/sda6/a8/a72/3g/iceCreamSandwish/backup/exmaple/list_file.txt"
function func_pull_files()
{
    local input_file=$1
    local full_path
    local backup_path
    local count=0

    while read -r line
    do
        let count=`expr $count + 1`
        if [ `expr match $line $ANDROID_FOLDER` == "$ANDROID_FOLDER_LEN" ] || 
           [ `expr match $line $KERNEL_FOLDER` == "$KERNEL_FOLDER_LEN" ] || 
           [ `expr match $line $UBOOT_FOLDER` == "$UBOOT_FOLDER_LEN" ];then
            echo "$count : right pull path"
            full_path=${COMMON_PATH}${line}
            backup_path=${B_FOLDER}`dirname $line`
            func_backup_file_by_path $full_path $backup_path
        else
            echo "$count : pull file $line is invalidate!"
        fi
    done < $input_file

}

func_copy_all_files()
{
    if [ ! -e "$LIST_FILE" ];then
        echo ERROR: the file $LIST_FILE not existes!!!
        exit 1
    fi


    case $1 in
        BB|bb)
            echo -e "\n\n==============backup files=============="
            func_pull_files $LIST_FILE && exit 0
            ;;
        TT|tt)
            echo -e "\n\n==============syn    files=============="
            func_push_files $LIST_FILE && exit 0
            ;;
        *)
            echo ERROR parameter: please input parameter \"bb\" to backup, or \"tt\" to update!!!
            ;;

    esac
}

func_copy_all_files $1

exit 0

 

點擊下載:bash實例

 

    


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM