在ansible中读取json就像变量一样

时间:2016-04-19 20:26:28

标签: ansible ansible-2.x

我是ansible的新手,我在从ansible角色的json文件中读取值时遇到问题。我的变量有如下值:

{
  "queue": {
    "first": {
      "car": "bmw",
      "year": "1990",
      "model": "x3",
      "color": "blue"
    },
    "second": {
      "car": "bmw",
      "year": "2000",
      "model": "318",
      "color": "red"
    }
  }
}

我正在尝试打印颜色的值,仅将其与其他变量进行比较。我使用with_dict迭代json对象(存储在名为jsonVar的变量中),如下所示:

- name: test loop
  with_dict: "{{jsonVar}}"
  shell:  |
        if echo "blue" | grep -q "${{item.value.color}}" ; then
           echo "success"

到目前为止,从if语句中将颜色值从json到“blue”进行比较是没有运气的。我想知道我做错了什么? 提前谢谢!

3 个答案:

答案 0 :(得分:10)

您可以使用名为file的查找插件读取json文件,并将其传递给from_json jinja2过滤器。您在with_dict循环中也有错误,因为您必须遍历jsonVar['queue'],而不仅仅是jsonVar。这是一个完整的代码:

---
- hosts: your_host
  vars:
    jsonVar: "{{ lookup('file', 'var.json') | from_json }}"
  tasks:
    - name: test loop
      with_dict: "{{ jsonVar['queue'] }}"
      shell: |
        if echo "blue" | grep -q "{{ item.value.color }}" ; then
            echo "success"
        fi

答案 1 :(得分:4)

您可以使用| json_query过滤器。

http://docs.ansible.com/ansible/playbooks_filters.html#json-query-filter

但请确保您输入的文件也是适当的格式,否则您可以使用两个过滤器,第一个转换为适当的过滤器,第二个过滤器执行json查询。

例如: - {{ variable_name | from_json | json_query('')}}

在你的情况下,我认为这会有所帮助:

tasks: print the color
set_fact:
  color1 : "{{ jsonVar | from_json | json_query('queue.[0].['color']')}}"
  color2 : "{{ jsonVar | from_json | json_query('queue.[1].['color']')}}"

但请注意Ansible版本

等要求

答案 2 :(得分:2)

2020年的答案,因为我只想弄清楚。假设文件名为vars.json,并且与您的yml位于同一目录。

---
- hosts: all
  gather_facts: no
  vars:
    position: second
    field: year
  tasks:
  - name: Include Site Vars
    include_vars: vars.json

  - name: Debug JSON Vars
    debug:
      msg: "{{ queue[position][field] }}"