bash shell关联数组总结
【原创】本博文为原创博文,引用或转发请注明原始出处和链接:https://www.cnblogs.com/dingbj/p/dict_array.html
什么是关联数组?
关联数组相对于索引数组,又称字典,这里我就不给具体定义了,可以百度。
通过对比普通索引数组,能够快速理解运用关联数组。在定义或者引用索引数组时,通常使用数字下标来索引数组中不同的元素,
而关联数组最大的差别是,元素是无序的,关联数组由特定格式的键值对组成,关联数组的键是唯一的,同时使用键作为下标来索引关联数组元素。当然,对于无变量类型的脚本语言,数字可以被看做特殊的字串,
也就是说,在关联数组的索引中,你也可以使用数字作为键。
定义和初始化关联数组
关联数组初始化赋值方式1
这种情况必须先声明再初始化,例如:
declare -A mydict #声明
mydict["name"]=guess
mydict["old"]=18
mydict["favourite"]=coconut
关联数组初始化赋值方式2:
以索引数组格式定义,只不过元素变成了键值对,这种方式不需要先声明,例如:
mydict=(["name"]=guess ["old"]=18 ["favourite"]=coconut] ["my description"]="I am a student")
也可以声明并同时赋值:
declare -A mydict=(["name"]=guess ["old"]=18 ["favourite"]=coconut ["my description"]="I am a student")
方式2中,和索引数组定义方式一样,直接在变量赋值语句的等号右侧用小括号定义,但括号内部元素格式不同:
元素格式为:["键"]=值,元素键值对之间以空格分隔。
关联数组的引用
引用某个元素时,和普通数组的区别:只是索引为键而已
例如:echo ${mydict["name"]},输出为guess
引用整个关联数组时,和普通数组的引用完全一样
例如:echo ${mydict[@]} 或 echo ${mydict[*]}
关联数组的操作
获取关联数组长度(元素的个数):
例如:echo ${#mydict[@]}
关联数组切片:
通常,索引数组时有序的,而关联数组是无序的,虽然关联数组的切片还是能输出,但输出元素的排列顺序在不同的电脑上是不相同的,因此建议不要使用分片操作;
关联数组元素值的替换:
echo ${mydict[@]/guess/xiaoli}
关联数组的删除:
unset mydict
获取关联数组索引列表:
格式:${!关联数组名[@或*]

注意,键“my description"在这里看不出是一个字符串整体
对关联数组元素直接进行运算:
使用let命令对未定义的元素进行算数计算时,默认值为0,例如:
let mydict['one']++

遍历关联数组元素:
(实际上是对键列表进行遍历,在循环中引用这些键)
同样需要注意的是,${!mydict[@]}和${!mydict[*]}使用双引号括住时的差别:
有@时,双引号括住能保证元素值有空格的情况下不会出问题,
而有*时,双引号括住后将解析为所有索引以空格分隔的字符串,如果再把这个字符串作为循环体中操作关联数组的索引,输出肯定为空。
当不使用引号括住时,只能针 对无空格的元素值才能表现正常,因此,遍历时通常使用有@的格式,并用双引号括住。
例如:

错误用法举例:
(有@或*,但没有双引号括住时,
${!mydict[*]}输出的是没有引号的键的列表,for解析时将有空格的”my description“键拆分为my和description,
但mydict根本就没定义这两个键,因此遍历时输出两个空行)


bash shell关联数组总结的更多相关文章
- 我们一起来学Shell - shell的数组
文章目录 什么是数组 数组中常用变量 数组的定义 小括号定义数组变量 小括号加键值对定义数组变量 分别定义数组变量 动态地定义数组变量 数组赋值的切片 遍历数组 关联数组 我们一起来学Shell - ...
- bash脚本中的普通数组和关联数组
1. 普通数组 bash支持一维数组(不支持多维数组),并且没有限定数组的大小.类似与C语言,数组元素的下标由0开始编号.获取数组中的元素要利用下标,下标可以是整数或算术表达式,其值应大于或等于0. ...
- [ SHELL编程 ] 数组、关联数组和awk数组
本文主要对shell编程中常用的数组.关联数组和awk数组定义.操作以及注意事项做个总结,并提供具体案例. 数组 数组定义:一对圆括号表示数组,数组元素之间用空格符号分割. Array=(val1 v ...
- SHELL脚本编程-普通数组(列表)和关联数组(字典)
SHELL脚本编程-普通数组(列表)和关联数组(字典) 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.数组相关概述 变量: 存储单个元素的内存空间 数组: 存储多个元素的连续的 ...
- shell练习--关于关联数组自增统计判断的学习
今天在书上看到了一个关联数组 let statarray["$ftype"]++ 这样一个操作,用来做索引的自增统计,所以记下来 #!/bin/bash #统计文件类型 #关于关 ...
- bash shell数组使用总结
本文为原创博文,转发请注明原创链接:https://www.cnblogs.com/dingbj/p/10090583.html 数组的概念就不多说了,大家都懂! shell数组分为索引数组和关联数 ...
- shell 之awk 关联数组高级应用
最近由于数据迁移过,有些用户信息需要再次确认下,也许数据量比较大,但是需要最终确认的比如说是用户ID和其对应的用户积分数,这样就会导致出现文本a(老的数据),文本b(新的数据).比如 这是文本a.tx ...
- shell之数组和关联数组
数组和关联数组 #!/bin/bash #定义数组1 array_var1=(1 2 3 4 5 6)# #定义数组2 array_var[0]="test1" array_var ...
- 使用bash关联数组统计单词
使用bash关联数组统计单词 从bash 4开始支持关联数组,使用前需要声明,即 declare -A map map[key1]=value1 map[key2]=value2 map=([key1 ...
随机推荐
- C# 生成6位短信验证码
1 private string VerifyCode() 2 { 3 Random random = new Random(); 4 return random.Next(100000, 99999 ...
- spark 系列之一 RDD的使用
spark中常用的两种数据类型,一个是RDD,一个是DataFrame,本篇主要介绍RDD的一些应用场景见代码本代码的应用场景是在spark本地调试(windows环境) /** * 创建 spark ...
- Dubbo SPI源码解析①
目录 0.Java SPI示例 1.Dubbo SPI示例 2.Dubbo SPI源码分析 SPI英文全称为Service Provider Interface.它的作用就是将接口实现类的全限定名 ...
- intellij idea svn不能更新和提交
进入设置–version control – subversion如下图,将前边的选项的勾全部去掉,点击ok
- redis错误解决
第一次运行redis-server的时候闪退 win+R运行cmd打开命令行 进入redis根目录 输入 redis-server.exe redis.windows.conf 查看运行状态 此时如果 ...
- java采坑之路
判断相等 字符串判断相等 String str1 = null; String str2 = "java金融"; // str1.eq ...
- IDEA 使用Git clone项目【建议】
1.在启动页点击Get from Version Control进行克隆,这样可以减少不必要克隆Bug. 2.项目目录保持一致(保证文件的正确性),父级目录不要有其它任何文件(防止文件名冲突) 3.通 ...
- Spring Data JPA简介 Spring Data JPA特点
Spring Data JPA 是Spring基于ORM框架.JPA规范的基础上封装的一套JPA 应用框架,底层使用了Hibernate 的JPA技术实现,可使开发者用极简的代码即可实现对数据的访问和 ...
- JDBC UPDATE误区
1 package com.lykion; 2 3 import java.sql.Connection; 4 import java.sql.PreparedStatement; 5 import ...
- zigzag压缩算法
前文 Base 128 Varints 编码(压缩算法) 介绍了Base 128 Varints这种对数字传输的编码,了解到了这种编码方式是为了最大程度压缩数字的.但是,在前文里,我们只谈论到了正数的 ...