python - 如何将 "key = value;"对的字符串转换为 ansible 中的字典?

标签 python ansible mariadb jinja2 galera

基本上我正在寻找这个,但对于 ansible/jinja2: Convert a comma separated string of key values pairs to dictionary

我从 mariadb galera 服务器 wsrep_provider_options 得到一个以分号分隔的键=值对列表:

mariadb_wsrep_provider_options_output = 'base_dir = /var/lib/mysql/; base_host = 192.168.1.101; base_port = 4567;'

在使用 ansible register 存储该输出后,我试图将其解析为字典,如下所示:

mariadb_wsrep_provider_options_output:
  base_dir: /var/lib/mysql/
  base_host: 192.168.1.101
  base_port: 4567
  ...

我试过这样的东西,但我不确定如何将它转换回 dict:

- debug:
    msg: "{% for item in mariadb_wsrep_provider_options_output.split(';') %} {{ item.split('=') }} {% endfor %}"

编辑:我让它处理以下任务,但它看起来很笨重:

- set_fact:
    new_var: "{{ new_var|d([]) + [{ 'key': item.split('=')[0]|trim, 'value': item.split('=')[1]|trim }] }}"
    loop: "{{ mariadb_wsrep_provider_options_output.split(';') }}"
- debug:
    var: new_var | items2dict

输出:

    "new_var|items2dict": {
        "base_dir": "/var/lib/mysql/",
        "base_host": "192.168.100.153",
        "base_port": "4567"
    }

最佳答案

试试这个

    - set_fact:
        new_var: "{{ dict(_keys|zip(_vals)) }}"
      vars:
        _arr: "{{ mdb_out.split(';')|map('trim')|select()|list }}"
        _keys: "{{ _arr|map('regex_replace', '^(.*?)=(.*)$', '\\1')|map('trim')|list }}"
        _vals: "{{ _arr|map('regex_replace', '^(.*?)=(.*)$', '\\2')|map('trim')|list }}"

给予

  new_var:
    base_dir: /var/lib/mysql/
    base_host: 192.168.1.101
    base_port: '4567'

您的代码稍作改动也可以正常工作

    - set_fact:
        new_var: "{{ new_var|d({})|combine({_key: _val}) }}"
      loop: "{{ mdb_out.split(';') }}"
      when: item|length > 0
      vars:
        _key: "{{ item.split('=')[0]|trim }}"
        _val: "{{ item.split('=')[1]|trim }}"

split 从 Ansible 2.11 开始可以用作过滤器。您可以在此处使用它代替 regex_replace。下面的任务给出了相同的结果

    - set_fact:
        new_var: "{{ dict(_keys|zip(_vals)) }}"
      vars:
        _arr: "{{ mdb_out.split(';')|map('trim')|select()|list }}"
        _keys: "{{ _arr|map('split', '=')|map('first')|map('trim')|list }}"
        _vals: "{{ _arr|map('split', '=')|map('last')|map('trim')|list }}"

关于python - 如何将 "key = value;"对的字符串转换为 ansible 中的字典?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/67324308/

相关文章:

mysql - 为什么与 MariaDB 10.2 RAND() 函数发生如此多的冲突?

mysql - 无法在 CentOS 上使用 MariaDB 编译 C 程序

python - 从 Python 中的文件中读取一些随机行

loops - 根据主机组安装不同的 PHP 包

python - 使用来自其他带字符串的列的条件创建新列

ansible - 使用 Ansible Cloudformation 模块配置 CoreOS 集群

python - 通过 key 中的共同值组合两个 ansible 字典

mysql - 获取时间范围 SQL 查询之外的最后一行

python - 解析错误

python - 将一维 Numpy 数组作为行添加到 DataFrame