2015年2月

bash整理 - 数组

BASH只支持一维数组,但参数个数没有限制。

  1. 数组赋值:
# 1
array=(var1 var2 var3 ... varN)

# 2
array=([0]=var1 [1]=var2 [2]=var3 ... [n]=varN)

# 3
array[0]=var1
arrya[1]=var2
##...
array[n]=varN
  1. 计算数组元素个数:
${#array[@]}  或者  ${#array[*]}

BASH的特殊参数 @* 都表示“扩展位置参数,从1开始”,但形式稍有差异,但在数组里使用好像是可以通用的。

  1. 打印整个数组:
echo ${array[*]}  或者 echo ${array[@]}
  1. 打印某一数组元素:
echo ${array[3]}
  1. 清除指定的单个数组元素:
unset array[2]
  1. 清除整个数组:
unset array
  1. 引用数组:
echo ${array[n]}
  1. 遍历数组:
filename=(`ls`)
for var in ${filename[@]};do
    echo $var
done
  1. 数组实用示例:
# 1、从 标准输入 读入n次字符串,每次输入的字符串保存在数组array里

i=0
n=5
while [ "$i" -lt $n ] ; do
    echo "Please input strings ... `expr $i + 1`"
    read array[$i]
    b=${array[$i]}
    echo "$b"
    i=`expr $i + 1`
done
 
# 2、将字符串里的字母逐个放入数组,并输出到标准输出

chars='abcdefghijklmnopqrstuvwxyz'
for (( i=0; i<26; i++ )) ; do
    array[$i]=${chars:$i:1}
    echo ${array[$i]}
done
 
##  ${chars:$i:1},表示从chars字符串的 $i 位置开始,获取 1 个字符。如果将 1 改为 3 ,就获取 3 个字符

bash整理 - 字符串

整理一下使用bash过程中遇到的字符串相关处理方法

  1. 取长度
str="abcd"
expr length $str   # 4
echo ${#str}       # 4
expr "$str" : ".*" # 4
  1. 查找子串的位置
str="abc"
expr index $str "a"  # 1
expr index $str "b"  # 2
expr index $str "x"  # 0
expr index $str ""   # 0
  1. 选取子串
str="abcdef"
expr substr "$str" 1 3  # 从第一个位置开始取3个字符, abc
expr substr "$str" 2 5  # 从第二个位置开始取5个字符, bcdef 
expr substr "$str" 4 5  # 从第四个位置开始取5个字符, def
 
echo ${str:2}           # 从第二个位置开始提取字符串, bcdef
echo ${str:2:3}         # 从第二个位置开始提取3个字符, bcd
echo ${str:(-6):5}      # 从倒数第二个位置向左提取字符串, abcde
echo ${str:(-4):3}      # 从倒数第二个位置向左提取6个字符, cde
  1. 截取子串
str="abbc,def,ghi,abcjkl"
echo ${str#a*c}     # 输出,def,ghi,abcjkl  一个井号(#) 表示从左边截取掉最短的匹配 (这里把abbc字串去掉)
echo ${str##a*c}    # 输出jkl,             两个井号(##) 表示从左边截取掉最长的匹配 (这里把abbc,def,ghi,abc字串去掉)
echo ${str#"a*c"}   # 输出abbc,def,ghi,abcjkl 因为str中没有"a*c"子串
echo ${str##"a*c"}  # 输出abbc,def,ghi,abcjkl 同理
echo ${str#*a*c*}   # 空
echo ${str##*a*c*}  # 空
echo ${str#d*f)     # 输出abbc,def,ghi,abcjkl, 
echo ${str#*d*f}    # 输出,ghi,abcjkl   
 
echo ${str%a*l}     # abbc,def,ghi  一个百分号(%)表示从右边截取最短的匹配 
echo ${str%%b*l}    # a             两个百分号表示(%%)表示从右边截取最长的匹配
echo ${str%a*c}     # abbc,def,ghi,abcjkl
  1. 字符串替换
str="apple, tree, apple tree"
echo ${str/apple/APPLE}   # 替换第一次出现的apple
echo ${str//apple/APPLE}  # 替换所有apple
 
echo ${str/#apple/APPLE}  # 如果字符串str以apple开头,则用APPLE替换它
echo ${str/%apple/APPLE}  # 如果字符串str以apple结尾,则用APPLE替换它
  1. 比较
[[ "a.txt" == a* ]]        # 逻辑真 (pattern matching)
[[ "a.txt" =~ .*\.txt ]]   # 逻辑真 (regex matching)
[[ "abc" == "abc" ]]       # 逻辑真 (string comparision) 
[[ "11" < "2" ]]           # 逻辑真 (string comparision), 按ascii值比较
  1. 翻转
#使用rev
echo "STRING" | rev

# 自定义函数
A="abcd def ghd;"
B=$(echo $A | rev)
echo "first way result= [$B]"

len=$(echo -n $A | wc -c )
rev=""
while [ $len -gt 0 ]
do
    B="$(echo -n $A | cut -b$len)"
    rev="$rev$B"
    len=$(($len-1))
done
echo "second way result=[$rev]"
echo