2

我有一个关联数组,它就像通常的双数组一样。

结构类似于:[ [0,1], [0,1,2] ]。代码:

declare -A array
array[0,0]=0
array[0,1]=1
array[1,0]=0
array[1,1]=1
array[1,2]=2

如何获得array[0]array[1]的长度?在此示例中:2 和 3。

谢谢你。

PS我试图搜索重复项。没有成功。如果不清楚:我不知道数组的长度。


效率测试后选择答案。这是基于@RenaudPacalet 回答的函数示例:

function getLength() {
    local k=$(eval "echo \${!$1[@]}")
    local re="(\<$2,[0-9])"
    echo $k | grep -Eo $re | wc -l
}

使用示例:getLength array 1在这个问题的情况下返回 3。

请记住,使用$(eval "echo \${!$1[@]}")${!array[@]}.

4

2 回答 2

3

您必须遍历数组键并计算您关心的键:没有类似的语法${array[0,*])

n0=0
n1=0
for key in "${!array[@]}"; do 
    [[ $key == 0,* ]] && ((n0++))
    [[ $key == 1,* ]] && ((n1++))
done
echo $n0
echo $n1

或者,使用数组来计算所有“第一级”索引

n=()
for key in "${!array[@]}"; do (( n[${key%%,*}]++ )); done
# then, print out the counts
for ind in "${!n[@]}"; do printf "%s\t%s\n" $ind "${n[$ind]}"; done
于 2017-08-08T13:45:52.863 回答
0
k=${!array[@]}
n=0
re="(\<$n,[0-9]+)"
echo $k | grep -Eo $re | wc -l
  1. 获取数组的键,
  2. 设置行索引,
  3. 为匹配的键创建一个正则表达式,
  4. 使用正则表达式过滤键并计算匹配数。

如果需要,请重复使用其他行索引。正则表达式有点棘手。\<是单词的开头(以避免10,10匹配0,)。$n,[0-9]+是当前行索引,后跟一个逗号和一个或多个数字。括起来的括号定界子表达式。

grep的-Eo选项将其置于扩展正则表达式模式,并将匹配的字符串用新行分隔,以便wc -l可以计算它们。

于 2017-08-08T13:12:20.800 回答