bash编程之数组和字符串处理

数组:

程序=指令+数据
    
    指令:
    数据:变量、文件

数组:存储过个元素的连续的内存空间;

变量:存储单个元素的内存空间;

数组名:整个数组只有一个名字;

数组索引:编号从0开始;
    
    数组名[索引],
    ${ARRAY_NAME[INDEX]}

注意:bash-4及之后的版本,支持自定义索引格式,而不仅仅是0,1,2 ...数字格式;此类数组称之为“关联数组”

声明数组:

如果往一个变量里边指定多个元素,如果没有声明为数组,只不过是当成多个元素的的那个字符串,declare -a NAME :声明索引数组declare -A NAME:声明关联数组

数组中元素的赋值方式:

(1)一次只赋值一个元素
    ARRAY_NAME[INDEX]=value

(2)一次赋值全部元素
    ARRAY_NAME=("VAL1""VAL2""VAL3" ...)

(3)只赋值特定元素;
    ARRAY_NAME=([0]="VAL1" [3]="VAL4" ...)

引用数组中的元素: ${ARRAY_NAME[INDEX]} ${ARRAY_NAME[*]}:引用数组中的所有元素

注意:引用时,只给数组名,表示引用下标为0的元素;

数组的长度(数组中元素的个数):

${#ARRAY_NAME[*]}${#ARRAY_NAME[@]}

示例:

生成10个随机数,并找出其中最大值;

#!/bin/bash#declare -a randdeclare -l max=0for i in {0..9};do
        rand[$i]=$RANDOM
        echo ${rand[$i]}
        [ ${rand[$i]} -gt $max ] && max=${rand[$i]}doneecho "MAX:$max"[root@centous1 ~]# ./123.sh773293356870254241086732703140529551975322949MAX:32703

练习:定义一个数组,数组中的元素是/var/log目录下所有以.log结尾的文件;统计其下标为偶数的文件中的行数之和;

#!/bin/bash#declare -a files
files=(/var/log/*.log)declare -i lines=0for i in $(seq 0 $[${#files[*]}-1]);do
        if [ $[$i%2] -eq 0 ];then
                let lines+=$(wc -l ${files[$i]} | cut -d' ' -f1)        fidoneecho "Lines:$lines"[root@centous1 ~]# ./lines.shLines:3153

数组元素切片:

${ARRAY_NAME[@]: offset:number} offset:要咯过的元素个数; number:要取出的元素个数;省略number时,表示取偏移量之后的所有元素;

向非稀疏数组中追加元素:

ARRAY_NAME[${#ARRAY_NAME[*]}=

删除数组中的某元素;

unset ARRAY[INDEX]

关联数组:

declare -A ARRAY_NAME
    
    ARRAY_NAME=([index_name1]="value" ...)

bash的内置字符串处理工具:

字符串切片:

取字符串的字串;
去字符串的最右侧的几个字符:${var: -number}
注意:冒号后边必须有一个空白字符;
[root@centous1 ~]# name=jarry[root@centous1 ~]# echo ${name:2:2}rr
[root@centous1 ~]# echo ${name:2}rry
[root@centous1 ~]# echo ${name: -2}ry

基于模式取字符串;

${var#*word}:其中word是指定的分隔符;功能:自左而右,查找var变量所储存的字符串中,第一次出现的word分隔符,删除此分隔符至字符尾部之间的所有字符;${var##*word}:其中word是指定的分隔符;功能:自左而右,查找var变量所储存的字符串中,最后一次出现的word分隔符,删除此分隔符至字符尾部之间的所有字符;
[root@centous1 ~]# mypath="/etc/init.d/functions"[root@centous1 ~]# echo ${mypath#*/}etc/init.d/functions
[root@centous1 ~]# echo ${mypath##*/}functions

${var%word*}:其中word是指定的分隔符;功能:自右而左,查找var变量所储存的字符串中,第一次出现的word分隔符,删除此分隔符至字符尾部之间的所有字符;

${var%%word*}:其中word是指定的分隔符;功能:自右而左,查找var变量所储存的字符串中,最后一次出现的word分隔符,删除此分隔符至字符尾部之间的所有字符;

[root@centous1 ~]# echo ${mypath%/*}/etc/init.d
[root@centous1 ~]# url=http://www.magedu.com:80[root@centous1 ~]# echo ${url%%:*}http
[root@centous1 ~]# echo ${url##*:}80

注意 * 的位置

查找替换:

${var/PATTERN/SUBSTI}:查找var所表示的字符串中,第一次被PATTERN所匹配到的字符串,将其替换为SUBSSTI所表示的字符串;${var//PATTERN/SUBSTI}:查找var所表示的字符串中,第一次被PATTERN所匹配到的字符串,将其替换为SUBSSTI所表示的字符串;${var/#PATTERN/SUBSTI}:查找var所表示的字符串中,行首被PATTERN所匹配到的字符串,将其替换为SUBSSTI所表示的字符串;${var/%PATTERN/SUBSTI}:查找var所表示的字符串中,行尾被PATTERN所匹配到的字符串,将其替换为SUBSSTI所表示的字符串;

注意:PATTERN中使用golb风格和通配符;

查找删除:

${var/PATTERN}:删除匹配到的第一个

${var//PATTERN}:删除全部匹配到的

${var/%PATTERN}:删除匹配到的尾部那一个

${var/#PATTERN}:删除匹配到的行首那一个

字符大小写转换:

${var^^}:把var中的所有转换成大写

 ${var,,}:把var中的所有转换成大写

变量赋值:

${var:-value}:如果var变量为空,或未设置,那么返回VALUE;否则,返回var变量的值;${var:=value}:如果var变量为空,或未设置,那么返回VALUE;并将VALUE的值赋给var;否则,返回var变量的值;${var:+value}:如果var变量不空,则返回VALUE;${var:?ERROR_INFO}:如果var为空,或未设置,那么返回ERROR_INFO为错误提示;否则,返回var的值;

原创文章,作者:forest,如若转载,请注明出处:http://www.178linux.com/39324

(0)
forestforest
上一篇 2016-08-24 10:45
下一篇 2016-08-24 11:20

相关推荐

  • Linux磁盘管理进阶

    Linux磁盘管理进阶 dd命令 SWAP与移动介质 磁盘配额 RAID dd命令 dd – convert and copy a file Copy a file, converting and formatting according&…

    Linux干货 2016-09-05
  • 重构-改善既有代码的设计:重构原则(二)

    1.什么是重构 重构(Refactoring):在不改变软件的功能和外部可见性的情况下,为了改善软件的结构,提高清晰性、可扩展性和可重用性而对软件进行的改造,对代码内部的结构进行优化。 2.为何重构   1)改进软件设计(整理代码) 重构和设计是相辅相成的,它和设计彼此互补。有了重构,你仍然必须做预先的设计,但是不必是最优的设计,只需要一个合理的解…

    Linux干货 2015-04-07
  • Nginx负载均衡

    基于Nginx的负载均衡以及高可用简单应用 一、负载均衡配置 1、Nginx负载均衡配置 前面配置好的Nginx,可以访问之后,克隆4台,统一配置为512M,因为我的电脑内存是4G的。一台用来访问,一台用来做调度器(Director),两台web服务器(real server),Nginx前面已经介绍过了,故在此简单介绍一下那台Director的配置。 2、…

    Linux干货 2016-12-29
  • week5

    1、显示当前系统上root、fedora或user1用户的默认shell; useradd fedora useradd user1 egrep "^(root|fedora|user1)" /etc/passwd | cut -d: -f1,7 2、找出/e…

    Linux干货 2016-11-24
  • 上古神器vim

    概述:     在之前的篇章中,我们介绍了一些文本的处理工具,如grep、sed、cut、sort等,但是那些工具的侧重点都在于有了现成的文本之后,对现有的文本进行一定条件的加工处理后,满足我们进一步对数据的要求。但是目前为止,还没有接触一款专业用来编辑文本的工具,本篇就来介绍一下Linux系统上自带的专业用来文本编辑…

    Linux干货 2016-08-10
  • 2班jackcui20160802作业

    1、每日课堂笔记总结 2、预习 3、每日课堂pdf练习 4、在/data/testdir里创建的新文件自动属于g1组,组g2的成员如:alice能对这些新文件有读写权限,组g3的成员如:tom只能对新文件有读权限,其它用户(不属于g1,g2,g3)不能访问这个文件夹。 [root@centos7 /]# groupadd g1 [root@centos7 /…

    Linux干货 2016-08-05