[work] Bash 將字串拆分成陣列
阿新 • • 發佈:2018-12-18
split string to array in bash
和AS中的String.split不同,Bash沒有類似的語法,但它實在是太靈活了,有很多種方式可以做類似的事情。
以前我寫過一篇 Bash陣列操作教程 ,今天使用Bash做檔案處理的時候,發現有必要再寫一篇將字串拆分成陣列的教程。但發現有人已經寫了更好的教程在前面了,於是就偷懶轉過來好了。
以空白作為分隔符來拆分字串構造陣列
ARR=($STR)
注意$STR不能加引號。
1 2 3 4 |
STR="Hello World" ARR=($STR) declare -p ARR declare -a ARR='([0]="Hello" [1]="World")' |
用指定分隔符來拆分字串構造陣列
如果分隔符不是空白,而是別的,那麼需要藉助IFS變數。
default IFS (Internal Field Separator, which is space/tab/new line)
1 2 3 4 5 |
echo $PATH /usr/kerberos/sbin:/usr/kerberos/bin:/usr/apache/apache-ant-1.7.1/bin:/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin IFS=: DIRS=($PATH) declare -p DIRS declare -a DIRS='([0]="/usr/kerberos/sbin" [1]="/usr/kerberos/bin" [2]="/usr/apache/apache-ant-1.7.1/bin" [3]="/usr/local/sbin" [4]="/usr/local/bin" [5]="/sbin" [6]="/bin" [7]="/usr/sbin" [8]="/usr/bin" [9]="/root/bin")' |
但是下面的方式是不行的。
1 2 3 4 5 |
echo $PATH /usr/kerberos/sbin:/usr/kerberos/bin:/usr/apache/apache-ant-1.7.1/bin:/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin IFS=: declare -a DIRS=($PATH) declare -p DIRS declare -a DIRS='([0]="/usr/kerberos/sbin:/usr/kerberos/bin:/usr/apache/apache-ant-1.7.1/bin:/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin")' |
使用read -a來拆分字串構造陣列
All work and no play makes Jack a dull boy. 只會用功不玩耍,聰明孩子也變傻。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 |
PROVERB="All work and no play makes Jack a dull boy." read -a WORDS <<< $PROVERB echo "$WORDS" All echo "${#WORDS}" 3 echo "${WORDS[*]}" All work and no play makes Jack a dull boy. echo "${WORDS[@]}" All work and no play makes Jack a dull boy. echo "${#WORDS[*]}" 10 echo "${#WORDS[@]}" 10 |
前面的例子中要分割的字串是以空格分割的,現在舉一個以:分割的例子。
1 2 3 4 5 |
echo $IFS IFS=: read -r -a DIRS <<< "$PATH" echo $IFS declare -p DIRS declare -a DIRS='([0]="/usr/kerberos/sbin" [1]="/usr/kerberos/bin" [2]="/usr/apache/apache-ant-1.7.1/bin" [3]="/usr/local/sbin" [4]="/usr/local/bin" [5]="/sbin" [6]="/bin" [7]="/usr/sbin" [8]="/usr/bin" [9]="/root/bin")' |
下面的例子是將當前工作目錄以/進行分割。
1 2 3 4 5 6 7 8 |
echo $PWD /root/work191/ct08/src/ctmw IFS=/ read -r -a PARTS <<< $PWD declare -p PARTS declare -a PARTS='([0]=" root work191 ct08 src ctmw")' IFS=/ read -r -a PARTS <<<"$PWD" declare -p PARTS declare -a PARTS='([0]="" [1]="root" [2]="work191" [3]="ct08" [4]="src" [5]="ctmw")' |
使用cut命令分隔字串
1 |
echo "$STR" | cut -f $N |
以TAB分隔,列印第N個子串值,N從1開始計數。
1 |
echo "$STR" | cut -d "$DELIM" -d $N |
以指定DELIM分隔,列印第N個子串值,N從1開始計數。 其中,-d部分也可以是$N1,$N2,$N3的形式,即輸出多個子串。
A good beginning is half done. 良好的開端是成功的一半。
1 2 3 4 5 6 7 8 9 |
STR="A good beginning is half done." echo $STR | cut -d ' ' -f 2 good echo $PATH /usr/kerberos/sbin:/usr/kerberos/bin:/usr/apache/apache-ant-1.7.1/bin:/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin echo $PATH | cut -d ':' -f 3 /usr/apache/apache-ant-1.7.1/bin echo $PATH | cut -d ':' -f 3,5 /usr/apache/apache-ant-1.7.1/bin:/usr/local/bin |
使用awk命令分隔字串
1 2 |
echo "$STR" | awk '{print $1}' echo "$STR" | awk '{print $2}' |
注意:awk後面的引數用單引號,不能用雙引號。
1 2 3 4 5 6 7 |
STR="A good beginning is half done." echo "$STR" | awk '{print $1}' A echo "$STR" | awk '{print $2}' good echo "$STR" | awk '{print $5,$6}' half done. |