我正在尝试将物品列表转换为地图。
键应与项目中的键匹配,并在每个元素上使用相同的键递增。
也许一个例子会更加不稳定
variable "list" {
type = list(map(string))
default = [
{ a : "a", k : "node" },
{ a : "b", k : "node" },
{ a : "c", k : "master" },
{ a : "d", k : "master" }
]
}
// Output wanted
// {
// "node-0" : {a: a},
// "node-1" : {a: b},
// "master-0" : {a: c},
// "master-1" : {a: d}
// }
谢谢
答案 0 :(得分:3)
我准备了not-so-pretty
的实现方式。也许花更多的时间可以找到更好的解决方案,但至少可以将其视为迈向解决方案的第一步。
想法是创建一个helper_map
,与您之前的问题相同。通过一点按键和值的操作,就可以实现结果。
variable "list" {
type = list(map(string))
default = [
{ a : "a", k : "node" },
{ a : "b", k : "node" },
{ a : "c", k : "master" },
{ a : "d", k : "master" }
]
}
locals {
helper_map = {for idx,item in var.list: item["k"] => {a = item["a"]}...}
final_map = {for v1 in flatten([
for key, item in local.helper_map: [
for idx, val in item: {
"${key}-${idx}" = val
}
]
]): keys(v1)[0] => values(v1)[0]}
}
output "test2" {
value = local.final_map
}
结果:
test2 = {
"master-0" = {
"a" = "c"
}
"master-1" = {
"a" = "d"
}
"node-0" = {
"a" = "a"
}
"node-1" = {
"a" = "b"
}
}