在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
表现得很好。
谢谢!
答案 0 :(得分:11)
你必须深入研究参数扩展标志的精彩世界:) k
和v
标志可以一起用来强制关联数组扩展到它的键和值。
$ 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
。