ansible 扁平化地图过滤结果

Tod*_*wis 2 dictionary jinja2 ansible

我正在使用 Ansible 的地图过滤器来提取数据,但输出是一个列表列表;我需要的是一个扁平化的列表。下面的“energy.yml”剧本说明了我最接近的情况。调用为

ansible-playbook ./energy.yml --extra-vars='src=solar'

---
- hosts: localhost
  vars:
    region: [ 'east', 'west' ]
    sources:   
      wind:
        east:
          filenames:
            - noreaster.txt
            - gusts.txt
            - drafty.txt
        west:
          filenames:
            - zephyr.txt
            - jetstream.txt
      solar:
        east:
          filenames:
            - sunny.txt
            - cloudy.txt
        west:
          filenames:
            - blazing.txt
            - frybaby.txt
            - skynuke.txt
    src: wind
  tasks:
  - name: Do the {{ src }} data
    debug:
      msg: "tweak file '/energy/{{src}}/{{ item[0] }}/{{ item[1] }}'."
    with_nested:
      - "{{ region }}"
      - "{{ 
            (region|map('extract',sources[src],'filenames')|list)[0] +
            (region|map('extract',sources[src],'filenames')|list)[1]
         }}"
    when: "item[1] in sources[src][item[0]].filenames"
Run Code Online (Sandbox Code Playgroud)

map() 过滤器的输出是许多与“区域”长度相同的列表。Jinja 的“+”运算符是我发现的唯一一种连接列表的机制,但由于它是一个二元运算符而不是过滤器,我不能将它应用于任意数量的列表。上面的代码取决于长度为 2 的“区域”,并且必须多次 map() 非常丑陋。

重构数据(或问题)不是一种选择。我想关注的方面是展平 map() 输出,或者其他一些生成正确的“msg:”行的方式,上面的代码是这样做的

Kon*_*rov 5

sum过滤器start=[]是你的朋友:

region | map('extract',sources[src],'filenames') | sum(start=[])
Run Code Online (Sandbox Code Playgroud)

由此:

[
    [
        "noreaster.txt",
        "gusts.txt",
        "drafty.txt"
    ],
    [
        "zephyr.txt",
        "jetstream.txt"
    ]
]
Run Code Online (Sandbox Code Playgroud)

它会这样做:

[
    "noreaster.txt",
    "gusts.txt",
    "drafty.txt",
    "zephyr.txt",
    "jetstream.txt"
]
Run Code Online (Sandbox Code Playgroud)

  • 秘诀是“start=[]”——它强制 sum 连接数组,而不是默认整数。 (2认同)