首页 > 代码库 > shell字符串与数组总结

shell字符串与数组总结

博客主页:http://blog.csdn.net/minna_d


1. 计算字符串长度:

echo ${#str}

2. 按字符截取字符串:
${word:begin:length}

3.借助% 、%%、#、##对字符串的切割:
%:从右向左非贪婪匹配
%%:从右向左贪婪匹配
#:从左向右非贪婪匹配
##:从左向右贪婪匹配

用法示例: ${str%.*} ${str%%.*} ${str#*.} ${str##*.}
PS:"."这里仅仅只是一个普通的点,而不是任意字符

[root@jjy ~/q/data/tmp_data]# URL="hotel.qunar.com"
[root@jjy ~/q/data/tmp_data]# echo ${URL%.*}
hotel.qunar
[root@jjy ~/q/data/tmp_data]# echo ${URL%%.*}
hotel
[root@jjy ~/q/data/tmp_data]# echo ${URL#*.}
qunar.com
[root@jjy ~/q/data/tmp_data]# echo ${URL##*.}
com

4.利用IFS分割字符串

IFS为内置字段分隔符,这里有一篇关于IFS很好的说明:http://blog.chinaunix.net/uid-22566367-id-381955.html

PS:疑问,对于str=`ls -al`这种方式我弄不明白生成的到底是一个数组?还是算做一中字符串

[root@jjy ~/q/data/tmp_data]# IFS="\n"
[root@jjy ~/q/data/tmp_data]# str=`ls -al`
[root@jjy ~/q/data/tmp_data]# echo $str
总用量 20
drwxr-xr-x  2 root root 4096 1月   9 13:52 .
drwxr-xr-x 36 root root 4096 1月   7 19:53 ..
-rw-r--r--  1 root root   12 1月   9 13:51 1
-rw-r--r--  1 root root   10 1月   9 13:52 2
-rw-r--r--  1 root root   28 1月   9 13:51 2~
[root@jjy ~/q/data/tmp_data]# echo ${str[@]}
总用量 20
drwxr-xr-x  2 root root 4096 1月   9 13:52 .
drwxr-xr-x 36 root root 4096 1月   7 19:53 ..
-rw-r--r--  1 root root   12 1月   9 13:51 1
-rw-r--r--  1 root root   10 1月   9 13:52 2
-rw-r--r--  1 root root   28 1月   9 13:51 2~
[root@jjy ~/q/data/tmp_data]# 
[root@jjy ~/q/data/tmp_data]# echo ${str[*]}
总用量 20
drwxr-xr-x  2 root root 4096 1月   9 13:52 .
drwxr-xr-x 36 root root 4096 1月   7 19:53 ..
-rw-r--r--  1 root root   12 1月   9 13:51 1
-rw-r--r--  1 root root   10 1月   9 13:52 2
-rw-r--r--  1 root root   28 1月   9 13:51 2~
[root@jjy ~/q/data/tmp_data]# echo ${#str[@]}
1


第二部份:

1.计算数组长度:
${#array[@]}


2.列出数组索引:
${!array[*]}或者${!array[@]}

3.打印数组中所有值:
${array[*]}或者${array[@]}


4.shell中遍历数组元素:
for str in ${array[@]};
do
echo $str;
done


5.定义空数组

uset array


普通数组:

1.初始化:

第一种初始化

[root@jjy ~/q/data/tmp_data]# array_origin=(1 2 3 4)
[root@jjy ~/q/data/tmp_data]# echo ${#array_origin[@]}
4

第二种初始化


[root@jjy ~/q/data/tmp_data]# arra_origin[0]=00
[root@jjy ~/q/data/tmp_data]# arra_origin[1]=11
[root@jjy ~/q/data/tmp_data]# arra_origin[2]=22
[root@jjy ~/q/data/tmp_data]# arra_origin[3]=33


2.访问方式:

[root@jjy ~/q/data/tmp_data]# for item in ${arra_origin[@]}; do echo $item; done
00
11
22
33

<strong>PS:在awk中遍历数组的方式:</strong>
<span style="color:#FF6666;"><strong>i 代表的是key,而非value,切忌!切忌!</strong></span>

[root@jjy ~/q/data/tmp_data]# echo "1" | awk 'BEGIN{array[1]=11; array[2]=22;array[3]=33;array[4]=44} {for( i in array) {print i} }'
1
2
3
4
[root@jjy ~/q/data/tmp_data]# echo "1" | awk 'BEGIN{array[1]=11; array[2]=22;array[3]=33;array[4]=44} {for( i in array) {print array[i]} }'
11
22
33
44

关联数组:
第一种显示申明初始化:
[root@jjy ~/q/data/tmp_data]# declare -A ass_array_1

第二种内嵌索引值列表初始化:
[root@jjy ~/q/data/tmp_data]# ass_array_2=(["host1"]="192.168.1.23" ["ip1"]="192.168.1.23")

赋值:
[root@jjy ~/q/data/tmp_data]# ass_array["host"]="192.168.1.23"
[root@jjy ~/q/data/tmp_data]# ass_array["ip"]="192.168.1.23"

访问:
根据key查询value

[root@jjy ~/q/data/tmp_data]# echo ${ass_array_1["host"]}
192.168.1.23

查看所有key
[root@jjy ~/q/data/tmp_data]# echo ${!ass_array_1[*]}
host1 ip

查看所有value
[root@jjy ~/q/data/tmp_data]# echo ${ass_array[*]}
192.168.1.23 192.168.1.23


shell字符串与数组总结