如何在Python中的嵌套json中替换键中的字符

发布于 2025-01-10 02:30:29 字数 1165 浏览 0 评论 0原文

"127.0.0.1": {
        "nmaprun": {
            "@scanner": "nmap",
            "@args": "nmap -v -sS -sV -sC -A -O -oX nmap 127.0.0.1 1-1024",
            "@start": "1645467733",
            "@startstr": "Mon Feb 21 23:52:13 2022",
            "@version": "7.91",
            "@xmloutputversion": "1.05",
            "scaninfo": {
                "@type": "syn",
                "@protocol": "tcp",
                "@numservices": "1000",
                "@services": "1,3-4,6-7,9,13,17,19-26,
            },
            "verbose": {
                "@level": "1"
            },
            "debugging": {
                "@level": "0"
            },
        
            "runstats": {
                "finished": {
                    "@time": "1645467744",
                    "@timestr": "Mon Feb 21 23:52:24 2022",
                    "@summary": "Nmap done at Mon Feb 21 23:52:24 2022; 1 IP address (1 host up) scanned in 12.14 seconds",
                    "@elapsed": "12.14",
                    "@exit": "success"
                }
            }
        }
    }
}

我有 Nmap 的扫描输出。我想解析整个 JSON 并将“@”字符替换为“”。 我怎样才能在Python中做到这一点?

"127.0.0.1": {
        "nmaprun": {
            "@scanner": "nmap",
            "@args": "nmap -v -sS -sV -sC -A -O -oX nmap 127.0.0.1 1-1024",
            "@start": "1645467733",
            "@startstr": "Mon Feb 21 23:52:13 2022",
            "@version": "7.91",
            "@xmloutputversion": "1.05",
            "scaninfo": {
                "@type": "syn",
                "@protocol": "tcp",
                "@numservices": "1000",
                "@services": "1,3-4,6-7,9,13,17,19-26,
            },
            "verbose": {
                "@level": "1"
            },
            "debugging": {
                "@level": "0"
            },
        
            "runstats": {
                "finished": {
                    "@time": "1645467744",
                    "@timestr": "Mon Feb 21 23:52:24 2022",
                    "@summary": "Nmap done at Mon Feb 21 23:52:24 2022; 1 IP address (1 host up) scanned in 12.14 seconds",
                    "@elapsed": "12.14",
                    "@exit": "success"
                }
            }
        }
    }
}

I have this scan output from Nmap. I want to parse the entire JSON and replace the '@' character with ''.
how can I do this in python?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

唱一曲作罢 2025-01-17 02:30:29
dic = {"127.0.0.1": {
    "nmaprun": {
        "@scanner": "nmap",
        "@args": "nmap -v -sS -sV -sC -A -O -oX nmap 127.0.0.1 1-1024",
        "@start": "1645467733",
        "@startstr": "Mon Feb 21 23:52:13 2022",
        "@version": "7.91",
        "@xmloutputversion": "1.05",
        "scaninfo": {
            "@type": "syn",
            "@protocol": "tcp",
            "@numservices": "1000",
            "@services": "1,3-4,6-7,9,13,17,19-26",
        },
        "verbose": {
            "@level": "1"
        },
        "debugging": {
            "@level": "0"
        },

        "runstats": {
            "finished": {
                "@time": "1645467744",
                "@timestr": "Mon Feb 21 23:52:24 2022",
                "@summary": "Nmap done at Mon Feb 21 23:52:24 2022; 1 IP address (1 host up) scanned in 12.14 seconds",
                "@elapsed": "12.14",
                "@exit": "success"
            }
        }
    }
}}
def remove_at(d):
    if isinstance(d, dict):
        return {k.lstrip('@'): remove_at(v) for k, v in d.items()}
    elif isinstance(d, list):
        return [remove_at(v) for v in d]
    else:
        return d

print(remove_at(dic))
dic = {"127.0.0.1": {
    "nmaprun": {
        "@scanner": "nmap",
        "@args": "nmap -v -sS -sV -sC -A -O -oX nmap 127.0.0.1 1-1024",
        "@start": "1645467733",
        "@startstr": "Mon Feb 21 23:52:13 2022",
        "@version": "7.91",
        "@xmloutputversion": "1.05",
        "scaninfo": {
            "@type": "syn",
            "@protocol": "tcp",
            "@numservices": "1000",
            "@services": "1,3-4,6-7,9,13,17,19-26",
        },
        "verbose": {
            "@level": "1"
        },
        "debugging": {
            "@level": "0"
        },

        "runstats": {
            "finished": {
                "@time": "1645467744",
                "@timestr": "Mon Feb 21 23:52:24 2022",
                "@summary": "Nmap done at Mon Feb 21 23:52:24 2022; 1 IP address (1 host up) scanned in 12.14 seconds",
                "@elapsed": "12.14",
                "@exit": "success"
            }
        }
    }
}}
def remove_at(d):
    if isinstance(d, dict):
        return {k.lstrip('@'): remove_at(v) for k, v in d.items()}
    elif isinstance(d, list):
        return [remove_at(v) for v in d]
    else:
        return d

print(remove_at(dic))
踏月而来 2025-01-17 02:30:29

一种可能的方法是迭代键,然后弹出给定键的项目并将其分配给不带@的键,如果键以@开头,因为您有嵌套结构,所以您需要递归地遍历这些键

def recursive_replace(data):
    for key in data.keys():
        if key.startswith('@'):
            data[key[1:]] = data.pop(key)
            key = key[1:]
        if isinstance(data[key], dict):
            data[key]=recursive_replace(data[key])
    return data

输出:

>>> #assuming data holds the dictionary
>>> recursive_replace(data)
{
  "127.0.0.1": {
    "nmaprun": {
      "scaninfo": {
        "type": "syn",
        "protocol": "tcp",
        "numservices": "1000",
        "services": "1,3-4,6-7,9,13,17,19-26,"
      },
      "verbose": {
        "level": "1"
      },
      "debugging": {
        "level": "0"
      },
      "runstats": {
        "finished": {
          "time": "1645467744",
          "summary": "Nmap done at Mon Feb 21 23:52:24 2022; 1 IP address (1 host up) scanned in 12.14 seconds",
          "elapsed": "12.14",
          "exit": "success",
          "timestr": "Mon Feb 21 23:52:24 2022"
        }
      },
      "scanner": "nmap",
      "start": "1645467733",
      "startstr": "Mon Feb 21 23:52:13 2022",
      "version": "7.91",
      "xmloutputversion": "1.05",
      "args": "nmap -v -sS -sV -sC -A -O -oX nmap 127.0.0.1 1-1024"
    }
  }
}

One possible way is to iterate the keys, and then to pop the item for the given key and assign it to the key without @, if the key starts with @, since you have nested structure, you need to go through these keys recursively

def recursive_replace(data):
    for key in data.keys():
        if key.startswith('@'):
            data[key[1:]] = data.pop(key)
            key = key[1:]
        if isinstance(data[key], dict):
            data[key]=recursive_replace(data[key])
    return data

OUTPUT:

>>> #assuming data holds the dictionary
>>> recursive_replace(data)
{
  "127.0.0.1": {
    "nmaprun": {
      "scaninfo": {
        "type": "syn",
        "protocol": "tcp",
        "numservices": "1000",
        "services": "1,3-4,6-7,9,13,17,19-26,"
      },
      "verbose": {
        "level": "1"
      },
      "debugging": {
        "level": "0"
      },
      "runstats": {
        "finished": {
          "time": "1645467744",
          "summary": "Nmap done at Mon Feb 21 23:52:24 2022; 1 IP address (1 host up) scanned in 12.14 seconds",
          "elapsed": "12.14",
          "exit": "success",
          "timestr": "Mon Feb 21 23:52:24 2022"
        }
      },
      "scanner": "nmap",
      "start": "1645467733",
      "startstr": "Mon Feb 21 23:52:13 2022",
      "version": "7.91",
      "xmloutputversion": "1.05",
      "args": "nmap -v -sS -sV -sC -A -O -oX nmap 127.0.0.1 1-1024"
    }
  }
}
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文