AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 1161973
Accepted
Matt Wagner
Matt Wagner
Asked: 2024-07-04 04:09:13 +0800 CST2024-07-04 04:09:13 +0800 CST 2024-07-04 04:09:13 +0800 CST

Ansible:如何将列表和字典合并为新的嵌套字典

  • 772

我正在尝试为绑定建立反向查找(PTR)记录。

我有一个 CSV 文件,其中 IP 和主机名字段已加载到字典中(来自 read_csv),所以我猜它实际上是一个字典列表:

ok: [localhost] => {
    "msg": [
        {
            "changed": false,
            "dict": {},
            "failed": false,
            "list": [
                {
                    "hostname": "host1",
                    "ip": "10.32.1.32"                                                            
                },
                {
                    "hostname": "host2",
                    "ip": "10.50.6.71"                                                            
                },
                {                                                                                     
                    "hostname": "host3",
                    "ip": "10.36.254.41"                                                          
                },
                {
                    "hostname": "host4",
                    "ip": "10.36.254.42"
                }
            ]
        },
    ]
}

我有一个从上述字典中得出的唯一的反转最后两个八位字节列表:

ok: [localhost] => {
    "msg": [
        [
            "32.10",
            "50.10",
            "36.10"
        ],
    ]
}

我想要的是一个如下所示的新字典(格式可能不正确,请原谅):

{
   "32.10": 
          {
              "hostname": "host1",
              "ip": "10.32.1.32"                                                            
          },
   "50.10":
          {
              "hostname": "host2",
              "ip": "10.50.6.71"                                                            
          },
   "36.10":
          {                                                                                     
              "hostname": "host3",
              "ip": "10.36.254.41"                                                          
          },
          {
              "hostname": "host4",
              "ip": "10.36.254.42"
          }
}

新的“超级”字典应该只包含匹配网络的 IP + 主机名条目(例如,所有 10.36.xx 条目都应位于“36.10”下)。

从这个新的字典中,我应该能够在模板中循环它来生成 PTR 记录。

我不知道如何合并这两个数据结构。:-/

谢谢你!

ansible
  • 1 1 个回答
  • 12 Views

1 个回答

  • Voted
  1. Best Answer
    larsks
    2024-07-04T04:57:47+08:002024-07-04T04:57:47+08:00

    您可以使用combine过滤器来构建最终的词典。

    像这样:

    - hosts: localhost
      gather_facts: false
      vars:
        results:
          - hostname: host1
            ip: 10.32.1.32
          - hostname: host2
            ip: 10.50.6.71
          - hostname: host3
            ip: 10.36.254.41
          - hostname: host4
            ip: 10.36.254.42
      tasks:
        - loop: "{{ results }}"
          vars:
            reversed: {}
            key: >-
              {{"{}.{}".format(*((item.ip.split('.'))[:2]|reverse))}}
          set_fact:
            reversed: >-
              {{
              reversed|combine({key: reversed.get(key, []) + [item]}, list_merge='append_rp')
              }}
    
        - debug:
            var: "reversed"
    

    我们使用以下表达式构造字典键:

    {{"{}.{}".format(*((item.ip.split('.'))[:2]|reverse))}}
    

    这会将“abcd”之类的内容转换为“ba”。我们使用它 + 过滤器combine+过滤器list_merge的选项combine来获取最终的数据结构;上述剧本产生了以下输出:

    TASK [debug] *******************************************************************
    ok: [localhost] => {
        "reversed": {
            "32.10": [
                {
                    "hostname": "host1",
                    "ip": "10.32.1.32"
                }
            ],
            "36.10": [
                {
                    "hostname": "host3",
                    "ip": "10.36.254.41"
                },
                {
                    "hostname": "host4",
                    "ip": "10.36.254.42"
                }
            ],
            "50.10": [
                {
                    "hostname": "host2",
                    "ip": "10.50.6.71"
                }
            ]
        }
    }
    
    • 0

相关问题

  • Ansible:将字符串转换为字典

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve