如何将关联数组分配给zsh中的另一个变量?

时间:2013-10-09 23:03:58

标签: arrays shell associative-array zsh

在zsh中,有没有办法将关联数组分配给另一个变量?我想这样的事情:

typeset -A orig
orig=(key1 val1 key2 val2)
typeset -A other
other=$orig
print '$orig:  '$orig
print '$other: '$other
print '$orig[key1]: '$orig[key1]
print '$other[key1]: '$other[key1]

这将打印:

$orig:  val1 val2
$other: val1 val2
$orig[key1]: val1
$other[key1]: 

我希望能够使用$other[key1]并获取val1

我知道我可以迭代按键并逐项复制,但我真的想避免这种情况。此外,eval是邪恶的:)

我已经尝试了other=($orig)和其他变体,但这将从orig获取我的值,并像这样创建关联数组

other=(val1 val2)

所以other[key1]不返回任何内容,other[val1]返回val2,这不是我想要的。

如果我理解正确,我的每次尝试中发生的事情是$other正在获取$orig数组,而没有键。如何让它同时接收键并在它们之间建立正确的关联?

我不担心空值,如果这甚至是个问题, 因为我确信$orig表现得很好。

谢谢!

2 个答案:

答案 0 :(得分:11)

你必须深入研究参数扩展标志的精彩世界:) kv标志可以一起用来强制关联数组扩展到它的键和值。

$ typeset -A orig
$ orig=(key1 val1 key2 val2)
$ print ${(kv)orig}
key1 val1 key2 val2

然后,您可以使用set命令使用该扩展产生的交替键/值填充副本。

$ typeset -A other
$ set -A other ${(kv)orig}
$ print $other[key1]
val1

这些标志和其他标志记录在man zshexpn“参数扩展标志”下,这是我最喜欢的zsh功能之一。

答案 1 :(得分:3)

zsh: bad set of key/value pairs for associative array

没有逃脱的完美世界:

typeset -A old new
old=(k1 v1 k2 v2 k3 v3)
typeset old    # old=( k1 v1 k2 v2 k3 v3 )

...不存在,您的数组通常包含空值:

old[k2]=
typeset old    # old=( k1 v1 k2 '' k3 v3 )

...因此您需要使用"(引用),@(转义)和f(字段分隔):

typeset new    # new=( )
new=("${(@fkv)old}")
typeset new    # new=( k1 v1 k2 '' k3 v3 )

有关参数扩展标志的更多信息,请参阅man zshexpn