Map合集是一种以键值对形式存储数据的数据结构,本文为您介绍如何查看模板中的Map值。
查看单层映射值
您可以通过调用下列函数获取单层映射中的值。
不建议您在模板中的Mappings部分定义单层Map,ROS无法获取Mappings中单层Map的值。更多信息,请参见映射(Mappings)。
Fn::Select
推荐您使用该函数获取单层Map的值。
当输入为一个JSON对象时,调用Fn::Select函数获取key_a对应的value_a。更多信息,请参见Fn::Select。
ROSTemplateFormatVersion: '2015-09-01' Parameters: InputMap: Type: Json Outputs: value_a: Value: Fn::Select: - key_a - InputMap
您也可以直接在模板中构造字典获取值。
ROSTemplateFormatVersion: '2015-09-01' Resources: Mock: Type: MockResource Properties: Prop1: Fn::Select: - key - key1: value1 key2: value2
Fn::GetJsonValue
当输入为一个JSON字符串时,您可以调用Fn::GetJsonValue获取第一层的key所对应的value。更多信息,请参见Fn::GetJsonValue。
ROSTemplateFormatVersion: '2015-09-01'
Parameters:
InputMapJsonString:
Type: Json
Outputs:
value_a:
Value:
Fn::GetJsonValue:
- key_a
- InputMapJsonString
查看双层映射值
您可以通过调用下列函数获取双层映射中的值。
Fn::FindInMap
该函数只适用于查看在Mappings中定义的双层映射值。
您可以调用Fn::FindInMap函数获取模板中Mappings部分定义的双层映射值。更多信息,请参见映射(Mappings)和Fn::FindInMap。
ROSTemplateFormatVersion: '2015-09-01'
Parameters:
regionParam:
Description: 选择创建ECS的地域
Type: String
AllowedValues:
- hangzhou
- beijing
Mappings:
RegionMap:
hangzhou:
'32': m-25l0rcfjo
'64': m-25l0rcfj1
beijing:
'32': m-25l0rcfj2
'64': m-25l0rcfj3
Resources:
WebServer:
Type: ALIYUN::ECS::Instance
Properties:
ImageId:
Fn::FindInMap:
- RegionMap
- Ref: regionParam
- '32'
Fn::Select
该函数适用于查看非Mappings中定义的双层映射值。
您可以通过嵌套Fn::Select函数的方法获取双层映射中的值。更多信息,请参见Fn::Select。
Fn::Select:
- key_1_1:
- Fn::Select:
- key_1
- key_1:
key_1_1: value_1_1
key_1_2: value_1_2
key_2:
key_2_1: value_2_1
key_2_2: value_2_2
返回值:value_1_1。
查看多层映射值
您可以通过调用下列函数获取多层映射中的值。
Fn::Select
您可以通过嵌套Fn::Select和Fn::FindInMap函数获取Mappings中的多层映射值,ROS只支持通过Fn::FindInMap函数获取Mappings中的value。当您想获取Mappings中的多层映射值时,您可以先通过Fn::FindInMap获取双层映射的值,此时返回一个Map合集,然后再通过Fn::Select函数去获取想要的值。
Fn::Select: - key - Fn::FindInMap: - MapName - TopLevelKey - SecondLevelKey
您也可以通过多次嵌套Fn::Select函数的方法获取非Mappings中多层映射中的值。更多信息,请参见Fn::Select。
Fn::Jq
您可以通过设置多个筛选器来满足多层查找的需求。更多信息,请参见Fn::Jq。
Fn::Jq:
- All
- '.parameters[] | {"param_name": .name, "param_type":.type}'
- changeSet:
items: []
kind: git
id: 2013-12-27_00-09-37
parameters:
- name: PKG_TAG_NAME
value: trunk
- name: GIT_COMMIT
value: master
- name: TRIGGERED_JOB
value: trunk-buildall
返回值:
- param_name: PKG_TAG_NAME
- param_name: GIT_COMMIT
- param_name: TRIGGERED_JOB