对文本处理,单独用shell来处理还是比较薄弱。所以shell就引用了awk and sed这两个命令。我们今天不说这个

一 字符串
  字符串是shell编程中最常用最有用的数据类型,因为你定义一个变量,存的值就是一个字符串,字符串可以用单引号,也可以用双引号,也可以不用引号



A=1
name="lottu"
feel='happy'



  说下字符串的处理



1. 拼接字符串
       echo "${name} feels ${feel}"    #即空格就是字符串拼接

2. 求字符串长度
       echo ${#name}  
       echo `expr length $name`
       echo ${name} | awk '{print length($0)}'     #awk里面拥有丰富的函数,所以可以完全借鉴于它。

3.截取字符串
        echo ${name:1:4}                    #输出ottu。下标是从0开始;这跟其他语言不一样。
        expr substr "$name" 1 4
        echo ${name}|awk '{print substr($0,2,4)}'  #输出为ottu。

4. index检索子串--返回第一次出现的位置;若找不到,则返回1
         expr index "$name" lo

5. match匹配子串 --返回匹配到子串的长度;若找不到,则返回0
        expr match "$name" lott  #返回4         

6. 替换子串${string/substring/replacement}表示仅替换一次substring相配字符,而${string//substring/replacement}表示为替换所有的substring相配的子串
         str="you and me,go your home.OK? you" 
         echo ${str/you/tom}             
         echo ${str//you/tom}



 总结:灵活运用命令expr,以上实现效果都可以用awk来实现。本人对awk很熟悉;大家有什么文本处理的问题,可以找我。


 

二 数组

bash支持一维数组(不支持多维数组),并且没有限定数组的大小。类似与C语言,数组元素的下标由0开始编号。获取数组中的元素要利用下标,下标可以是整数或算术表达式,其值应大于或等于0



1. 定义数组
    在Shell中,用括号来表示数组,数组元素用“空格”符号分割开。定义数组的一般形式为:
    array_name=(value1 ... valuen)
    vname=("lottu" "li0924" "0924" "tom")

2. 打印数组值
    echo ${vname[2]} #输出"0924" ;大家理解?因为shell数组的下标是从0开始。
    使用使用@ 或 * 可以获取数组中的所有元素
    echo ${vname[@]}  or echo ${vname[*]}

3.获取数组长度
    其实跟字符串长度差不多
    echo ${#vname[*]} #输出为4;数组的个数
    求数组某个下标的值的长度
   echo ${#vname[1]}  #输出为6

4. 删除数组
    unset命令
    unset varray_name[n]  :删除第n+1个
    unset varray_name       删除数组 varray_name

5. 获取部分数组--格式:${数组名[@或*]:起始位置:长度}
  $ vname=("lottu" "li0924" "0924" "tom")
  $ echo ${vname[*]:0:2}
     lottu li0924
 
6. 扩展read 命令来定义数组使用参数a
   $ read -p "please input your number: " -a num 
    please input your number: 1 5 6 8
   $ echo ${num[*]}
    1 5 6 8