如何循环ansible json_查询

如何循环ansible json_查询,ansible,ansible-2.x,ansible-facts,json-query,Ansible,Ansible 2.x,Ansible Facts,Json Query,有没有办法简化下面的json_查询? 在这里,您可以看到我正试图使用三种查询设置来提取三个值。由于列表中有三个项目,因此该值将与项目列表对应生成三次。有没有办法将每个项目的值分开 ClusterName: xxxx for dv-cn-c1 DomainName: xxxx for dv-cn-c1 ClusterName: xxxx for dv-cn-c2 DomainName: xxxx for dv-cn-c2 请看我的想法 - name: "set fact for poli

有没有办法简化下面的json_查询? 在这里,您可以看到我正试图使用三种查询设置来提取三个值。由于列表中有三个项目,因此该值将与项目列表对应生成三次。有没有办法将每个项目的值分开

ClusterName: xxxx for dv-cn-c1
DomainName: xxxx for dv-cn-c1

ClusterName: xxxx for dv-cn-c2
DomainName: xxxx for dv-cn-c2
请看我的想法

   - name: "set fact for policy pkg for list of devices"
        set_fact:
          ClusterName: "{{ fullinvt  | json_query(query1) }}"
          DomainName: "{{ fullinvt  | json_query(query2) }}"
          PolicyName: "{{ fullinvt  | json_query(query3) }}"
        vars:
    #w       query: "ansible_facts.checkpoint_servers_gateways.objects[*].policy[].\"cluster-members-access-policy-revision\"[?name == 'dev-cn-c2'].name"
          query1: "ansible_facts.checkpoint_servers_gateways.objects[?\"cluster-member-names\"[?contains(@ `{{ item }}`)]].name | [0]"
          query2: "ansible_facts.checkpoint_servers_gateways.objects[?\"cluster-member-names\"[?contains(@ `{{ item }}`)]].domain.name | [0]"
          query3: "ansible_facts.checkpoint_servers_gateways.objects[?\"cluster-member-names\"[?contains(@ `{{ item }}`)]].policy.\"access-policy-name\" | [0]"
        with_items:
          - dv-cn-c1
          - dv-cn-c2
          - dv-cn-4
        tags: ADDLAG

您可以做的是构建一个字典字典,其中第一级键是循环中的项;第二级键对应的
ClusterName
DomainName
PolicyName

我创建了一个示例
playbook
,以更好地解释自己:

---
- name: Multiple json_queries
  hosts: local
  connection: local
  gather_facts: no
  vars_files:
    - ./secret.yml
  vars:
    fullinvt:
      dv-cn-c1:
        ClusterName: dv-cn-c1-cluster-name
        DomainName: dv-cn-c1-domain-name
        PolicyName: dv-cn-c1-policy-name
      dv-cn-c2:
        ClusterName: dv-cn-c2-cluster-name
        DomainName: dv-cn-c2-domain-name
        PolicyName: dv-cn-c2-policy-name
      dv-cn-4:
        ClusterName: dv-cn-4-cluster-name
        DomainName: dv-cn-4-domain-name
        PolicyName: dv-cn-4-policy-name
  tasks:
    - name: Create `json_query` object
      set_fact:
        # Multiline filter application
        result: >
          {{ 
            (result | default({})) | 
            combine({item: {
              "ClusterName": fullinvt | json_query('"' + item + '"' + ".ClusterName"),
              "DomainName": fullinvt | json_query('"' + item + '"' + ".DomainName"),
              "PolicyName": fullinvt | json_query('"' + item + '"' + ".PolicyName")
            }}) 
          }}
      loop:
        - dv-cn-c1
        - dv-cn-c2
        - dv-cn-4

    - debug:
        var: item
      loop: "{{ result | dict2items }}"
我没有创建全局事实,而是创建了一个名为
result
。循环中每个元素的数据都位于具有相同名称的键内

如果需要进一步循环此词典,可以使用
dict2items
过滤器,如
debug
任务所示


我希望这会有帮助。

据我所知,你只能设定一次事实。但是由于使用_items迭代
,您将多次设置相同的事实。因此,您的任务不会像您预期的那样工作。