Ansible'da bir json dosyası kayıtları arasında nasıl döngü yapılır

0

Soru

Ansible'da yeniyim, sadece ansible ile bir json kayıtlarında nasıl dolaşabileceğimi dolaşıyorum. İçinde aşağıdaki verilere sahip bir json dosyam var:

{
    "map": {
        "entry": [
            {
                "string": [
                    "6a032ae5-3eed-4d20-a9ef-ccbd88118c47"
                ]
            },
            {
                "string": [
                    "27617813-e268-4c94-b539-3550a3a8501a"
                ]
            },
            {
                "string": [
                    "b39b10fb-0538-42d7-96fc-553eee9c7ded"
                ]
            }
        ]
    }
}

ve json dosyası üzerinden çalıştırmak için ansible'da aşağıdaki kodum var:

- name: Initialise variables
  set_fact:
    NEW_CODE_TEMPLATES_IDS: "{{ lookup('file', 'code_template_map/codeTemplate.json') | json_query('map.entry[*].item') }}"
    
    
- name: code template id
  debug:
    var: NEW_CODE_TEMPLATES_IDS

Çıktının aşağıdaki gibi olmasını bekliyorum:

6a032ae5-3eed-4d20-a9ef-ccbd88118c47
27617813-e268-4c94-b539-3550a3a8501a
b39b10fb-0538-42d7-96fc-553eee9c7ded

Ama nedense burası bana göre bir yer görünmüyor olduğunu. kimse nedenini bilmiyor mu ?

ansible
2021-11-24 05:09:25
1

En iyi cevabı

1

Arama tarafından döndürülen dizeyi Json'dan bir veri yapısına dönüştürmüyorsunuz (json_query() JSON dizeleriyle kullanılamaz, ayrıştırılmış veri yapıları bekler) ve json_query('map.entry[*].item') sağladığınız verilerle eşleşmiyor.

Önermem json_query() ve bu veri manipülasyonu için standart Jinja özelliklerini kullanın:

"{{ (lookup('file', 'code_template_map/codeTemplate.json') | from_json).map.entry | map(attribute='string') | flatten }}"

Kullanmakta ısrar ediyorsanız json_query() olur :

"{{ (lookup('file', 'code_template_map/codeTemplate.json') | from_json) | json_query('map.entry[*].string[]') }}"
2021-11-24 06:21:42

Diğer dillerde

Bu sayfa diğer dillerde

Русский
..................................................................................................................
Italiano
..................................................................................................................
Polski
..................................................................................................................
Română
..................................................................................................................
한국어
..................................................................................................................
हिन्दी
..................................................................................................................
Français
..................................................................................................................
Česk
..................................................................................................................
Português
..................................................................................................................
ไทย
..................................................................................................................
中文
..................................................................................................................
Español
..................................................................................................................
Slovenský
..................................................................................................................