首页 > 代码库 > 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字符串与数组总结
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。