Ansible: Преобразование строки в словарь

Ansible: Преобразование строки в словарь

Я запускаю Ansible из Tower, затем заполняю новых пользователей текстом:

{ name: user1, uid: 5000 }
{ name: user2, uid: 5001 }

Я хотел бы перебрать этих пользователей в виде словаря, что-то вроде:

- name: Print vars
  debug:
    var: "{{ item.name }}"
  with_items: "{{ users.split('\n') }}"

Но это не работает:

TASK [Print vars] *********************************************************************************************************************
ok: [lx-test] => (item={ name: user1, uid: 5000 }) => {
    "ansible_loop_var": "item",
    "item": "{ name: user1, uid: 5000 }",
    "{ name: user1, uid: 5000 }": "VARIABLE IS NOT DEFINED!"
}
ok: [lx-test] => (item={ name: user2, uid: 5001 }) => {
    "ansible_loop_var": "item",
    "item": "{ name: user2, uid: 5001 }",
    "{ name: user2, uid: 5001 }": "VARIABLE IS NOT DEFINED!"
}

Есть идеи, как преобразовать эту строку в настоящий словарь? Спасибо заранее!

решение1

Обновлять

Выражение ниже

users_list: "{{ users_str.splitlines()|map('from_yaml')|list }}"

дает

users_list:
  - name: user1
    uid: 5000
  - name: user2
    uid: 5001

Объявите переменную каксоответствующий.


Пример полной схемы тестирования

- hosts: localhost

  vars:

    users_str: |
      {name: user1, uid: 5000}
      {name: user2, uid: 5001}

    users_list: "{{ users_str.splitlines()|map('from_yaml')|list }}"

  tasks:

    - debug:
        var: users_list

При желании можно поместить данные в CSV-файл.

shell> cat /tmp/users.csv 
name,uid
user1,5000
user2,5001

и использоватьсообщество.general.read_csvпрочитать это

- hosts: localhost

  tasks:

    - community.general.read_csv:
        path: /tmp/users.csv
      register: users
    - debug:
        var: users.list

дает (сокращенно)

  users.list:
  - name: user1
    uid: '5000'
  - name: user2
    uid: '5001'

Оригинальный ответ

Текст не является ни допустимым JSON, ни YAML. Вам придется разбить строки и читать словари построчно. Например, если текст

users_str: |
  {name: user1, uid: 5000}
  {name: user2, uid: 5001}

задача ниже

    - set_fact:
        users_list: "{{ users_list|d([]) + [item|from_yaml] }}"
      loop: "{{ users_str.splitlines() }}"

создает список словарей

users_list:
  - name: user1
    uid: 5000
  - name: user2
    uid: 5001

Итерация теперь тривиальна

    - debug:
        var: item.name
      loop: "{{ users_list }}"

дает

  item.name: user1
  item.name: user2

Связанный контент