数组的基本应用

                               数组

变量:存储单个元素的内存空间
v 数组:存储多个元素的连续的内存空间,相当于多个变量的集合。
v 数组名和索引

索引:编号从0开始,属于数值索引。

       元素数量为n-1
注意:索引可支持使用自定义的格式,而不仅是数值格式,即为关联索引, bash4.0版本之后开始支持。
bash的数组支持稀疏格式(索引不连续)
      
定义数组
v 声明数组:
declare -a ARRAY_NAME  可以不用定义
declare -A ARRAY_NAME: 关联数组    必须定义


v 数组元素的赋值:
(1) 一次只赋值一个元素;
ARRAY_NAME[INDEX]=VALUE

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

blob.png
(3) 只赋值特定元素:
ARRAY_NAME=([0]="VAL1" [3]="VAL2" …)

blob.png

 

 

(4) 交互式数组值对赋值
read -a ARRAY
blob.png
引用数组
v 引用数组元素: ${ARRAY_NAME[INDEX]}
注意:省略[INDEX]表示引用下标为0的元素
v 数组的长度(数组中元素的个数)
${#ARRAY_NAME[*]} 或 ${#ARRAY_NAME[@]}

blob.png
数组数据处理
v 引用数组中的元素:
所有元素: ${ARRAY[@]}, ${ARRAY[*]}
数组切片: ${ARRAY[@]:offset:number}
offset: 要跳过的元素个数  number: 要取出的元素个数  

blob.png 

    

 

向数组中追加元素:    
ARRAY[${#ARRAY[*]}]    从最后一个索引开始追加   

blob.png
v 删除数组中的某元素:导致稀疏格式
unset ARRAY[INDEX]

blob.png 

删除了编号为[2]的数据,剩下的编号为【0】【1】【3】【4】【5
v 关联数组:
declare -A ARRAY_NAME
ARRAY_NAME=([idx_name1]='val1' [idx_name2]='val2‘…)


字符串处理
v bash的字符串处理工具:
v 字符串切片:
${#var}:返回字符串变量var的长度

blob.png
${var:offset}:返回字符串变量var中从第offset个字符后(不包括第offset个字符)的字符开始,到最后的部分,offset的取值在0 ${#var}-1 之间(bash4.2后,充许为负值)

blob.png

 

 

 

 

${var:offset:number}:返回字符串变量var中从第offset个字符后(不包括第offset个字符)的字符开始,长度为number的部分

blob.png 

${var: -lengh}:取字符串的最右侧几个字符:
注意:冒号后必须有一空白字符

blob.png 

从右侧开始,取3个字符
字符串处理
v 基于模式取子串:
${var#*word}:其中word可以是指定的任意字符
功能:删除从左开始第一次匹配到的adm之前的内容,包括adm

blob.png
${var##*word}

功能:删除从左面开始最后一次匹配到的adm之前的内容,包括adm
blob.png
字符串处理
v ${var%word*}:其中word可以是指定的任意字符;
功能:删除从右边开始第一次匹配到的adm之后的内容,包括adm

blob.png
v ${var%%word*}:删除从右边开始最后一次匹配到的adm之后的内容,包括adm

blob.png
blob.png
字符串处理
v 查找替换:
${usb/adm/name}:将从左往右第一次匹配到的adm替换成name

blob.png 

${usb//adm/name}:将字符串中所有匹配到的adm替换成name

blob.png
${usb/#:/y}:将行首被匹配到的字符串 :替换成 y

blob.png
${usb/%nologin/yes}:将行尾被nologin匹配到的字符替换成yes

blob.png
字符串处理
v 查找并删除:
blob.png

v 字符大小写转换:
${usb^^}:把var中的所有小写字母转换为大写
${usb,,}:把var中的所有大写字母转换为小写
blob.png
变量赋值
v ${var:-value}:如果var为空或未设置,那么返回value;否则,则返回var的值
v ${var:+value}:如果var不空,则返回value
v ${var:=value}:如果var为空或未设置,那么返回value,并将value赋值给var;否则,则返回var的值

blob.png
v

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

(0)
zzdzzd
上一篇 2016-08-24 10:12
下一篇 2016-08-24 10:12

相关推荐

  • 双主模型的lvs-dr高可用负载均衡集群

    实验目的:使用keepalived实现lvs-dr模型双主高可用集群 实验环境:两台virtual server(实现lvs的双主)、两台real server(安装web service,用于负载均衡)、一台clietn用于验证结果 注意:为了不影响实验结果,在实验开始前先关闭iptables和selinux 操作步骤: 一、配置IP 1.配置A主机的IP…

    2017-05-13
  • ntp时间服务器

    前言   ntp(Network Time protocol)是网络时间协议,是用来使网络中的各个计算机时间同步的一种协议。 ntp配置  1)ntp是由ntp软件提供,如果没有可以使用yum进行安装  2)ntp配置文件介绍:/etc/ntp.conf   利用restrict来管理权限控制;语法格式:restric…

    Linux干货 2015-06-24
  • linux基础中的基础 —- 用户管理、文本处理、正则表达式等命令的使用(博客第三周作业)

    1、列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次即可。     who | cut -d' ' -f1 | uniq 2、取出最后登录到当前系统的用户的相关信息。     who | tail -1 3、取出当前系统上被用户当作其默认shell的最…

    Linux干货 2016-07-22
  • 搭建yum仓库

    搭建yum仓库 背景: 在学习完如何搭建yum仓库后,觉得搭建yum仓库很有意义,将自己学习中的感悟和理解记录下来,以备日后复习。 介绍: yum:全称是Yellow dog Updater, Modified。它是一个在Fedora和RedHat以及CentOS中的Shell前端软件包管理器。基于RPM包管理,能够从指定的服务器自动下载RPM包并且安装,可…

    2017-08-05
  • Linux中的文本处理工具—sed

    sed 处理文本工具 一、概述   Stream EDitor,行编辑器    sed是一种流编辑器,它一次处理一行内容。处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间”(pattern space),接着用sed命令处理缓冲区中的内容,处理完成后,把缓冲区的内容送往屏幕。接着处理下一行,这样不断重复,直到文件末尾。文…

    Linux干货 2016-08-10
  • 任务计划1

    at.allow :优先级高,有此文件,deny无效,只有此文件中的用户可使用at at.deny:优先级低,此文件中的用户拒绝,不在此文件允许 如果都没有,全都拒绝普通用户     [root@localhost ~]# rpm -q  at at-3.1.13-22.el7.x86_64 [root@localhost ~]…

    Linux干货 2017-05-15

评论列表(1条)

  • 马哥教育
    马哥教育 2016-08-26 11:16

    文章对数组定义和调用等知识点整理的1很详细,如果嫩能够对于数组的实际应用实例有些详细的介绍,就更好了哦