用于创建地图的 Terraform 插值
Terraform interpolation for creating a map
我正在为这个插值而苦苦挣扎,我有下面的变量。
primary = ["foo.dev","all.bar.com"]
secondary = ["module.foo.dev","*.foo.dev","all.bar.com"]
我希望我的输出是
{
"foo.dev" = ["module.foo.dev","*foo.dev"]
"all.bar.com" = ["all.bar.com"]
}
使用 Terraform 0.12.20
我在 terraform console 中尝试过,我无法获得我想要的输出。有什么简单的解决办法吗?
[for i in ["foo.dev","all.bar.com"]: map(i,[for j in ["module.foo.dev","*foo.dev","all.bar.com"]: replace(j,i,"")!=j == true ? j : 0])]
[
{
"foo.dev" = [
"module.foo.dev",
"*foo.dev",
"0",
]
},
{
"all.bar.com" = [
"0",
"0",
"all.bar.com",
]
},
]
您可以使用以下表达式执行此操作:
{ for i in ["foo.dev", "all.bar.com"] : i => [for j in ["module.foo.dev", "*foo.dev", "all.bar.com"] : j if can(regex(i, j))] }
这导致以下值:
{
"all.bar.com" = [
"all.bar.com",
]
"foo.dev" = [
"module.foo.dev",
"*foo.dev",
]
}
这正是您所要求的。
迭代解释如下:
首先,指定类型为地图:
{}
现在,我们应该遍历第一个列表中的元素:
{ for i in ["foo.dev", "all.bar.com"] : }
接下来,我们将i
值赋值给map的key,并为value初始化一个list:
{ for i in ["foo.dev", "all.bar.com"] : i => [] }
但是,我们需要将第二个列表中的元素的值分配给结果映射的键列表(下面的示例是次优的,因为我们不需要 for
表达式, 但它是下一步的说明):
{ for i in ["foo.dev", "all.bar.com"] : i => [for j in ["module.foo.dev", "*foo.dev", "all.bar.com"] : j] }
最后,我们要根据key过滤list value中的元素。我们可以在 regex
函数之外使用 can
函数来 return 一个基于是否匹配的布尔值。我们将其用于判断是否应将第二个列表的元素添加到值列表中的条件:
{ for i in ["foo.dev", "all.bar.com"] : i => [for j in ["module.foo.dev", "*foo.dev", "all.bar.com"] : j if can(regex(i, j))] }
我们已经找到了解决方案。
我正在为这个插值而苦苦挣扎,我有下面的变量。
primary = ["foo.dev","all.bar.com"]
secondary = ["module.foo.dev","*.foo.dev","all.bar.com"]
我希望我的输出是
{
"foo.dev" = ["module.foo.dev","*foo.dev"]
"all.bar.com" = ["all.bar.com"]
}
使用 Terraform 0.12.20
我在 terraform console 中尝试过,我无法获得我想要的输出。有什么简单的解决办法吗?
[for i in ["foo.dev","all.bar.com"]: map(i,[for j in ["module.foo.dev","*foo.dev","all.bar.com"]: replace(j,i,"")!=j == true ? j : 0])]
[
{
"foo.dev" = [
"module.foo.dev",
"*foo.dev",
"0",
]
},
{
"all.bar.com" = [
"0",
"0",
"all.bar.com",
]
},
]
您可以使用以下表达式执行此操作:
{ for i in ["foo.dev", "all.bar.com"] : i => [for j in ["module.foo.dev", "*foo.dev", "all.bar.com"] : j if can(regex(i, j))] }
这导致以下值:
{
"all.bar.com" = [
"all.bar.com",
]
"foo.dev" = [
"module.foo.dev",
"*foo.dev",
]
}
这正是您所要求的。
迭代解释如下:
首先,指定类型为地图:
{}
现在,我们应该遍历第一个列表中的元素:
{ for i in ["foo.dev", "all.bar.com"] : }
接下来,我们将i
值赋值给map的key,并为value初始化一个list:
{ for i in ["foo.dev", "all.bar.com"] : i => [] }
但是,我们需要将第二个列表中的元素的值分配给结果映射的键列表(下面的示例是次优的,因为我们不需要 for
表达式, 但它是下一步的说明):
{ for i in ["foo.dev", "all.bar.com"] : i => [for j in ["module.foo.dev", "*foo.dev", "all.bar.com"] : j] }
最后,我们要根据key过滤list value中的元素。我们可以在 regex
函数之外使用 can
函数来 return 一个基于是否匹配的布尔值。我们将其用于判断是否应将第二个列表的元素添加到值列表中的条件:
{ for i in ["foo.dev", "all.bar.com"] : i => [for j in ["module.foo.dev", "*foo.dev", "all.bar.com"] : j if can(regex(i, j))] }
我们已经找到了解决方案。