RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 1606731
Accepted
Иван Максимович
Иван Максимович
Asked:2025-02-12 04:13:34 +0000 UTC2025-02-12 04:13:34 +0000 UTC 2025-02-12 04:13:34 +0000 UTC

根据条件将字典键收集到单独的列表中

  • 772

有一本字典。这些键与示例中的不同。字典中的含义要么是字典,要么是文本。

有必要在单独的列表中收集从根到具有文本值的键的键分支。带有键的列表也需要收集到最终列表中。

我看到了一个使用递归的实现。我理解,使用班级检查功能是必要的。但我不明白具体怎么做。

以下是我想做的事情:

dict1 = {'1':{'2':{'3':'text'},'4':{'5':{'6':'text'},'7':'text'}},'8':{'9':{'10':'text'}}}
    
general_list = []
def search_keys(dict1, list_key=[]):
    for key, value in dict1.items():
        list_key.append(key)
        if isinstance(value, dict):
            search_keys(value, list_key)
        elif isinstance(value, str):
            general_list.append(list_key.copy())
            list_key.clear()
    return general_list
    
print(search_keys(dict1))

第一遍收集钥匙。从第二个开始,一切都出错了:

[['1','2','3'],['4','5','6'],['7'],['8','9','10']]

您应该获得以下内容:

[['1','2','3'],['1','4','5','6'],['1','4','7'],['8','9','10']]
python
  • 1 1 个回答
  • 36 Views

1 个回答

  • Voted
  1. Best Answer
    Stanislav Volodarskiy
    2025-02-12T05:07:16Z2025-02-12T05:07:16Z

    你清理得太快了list_key,一下子就把所有东西都洗干净了。在这个函数调用中你只需要删除你添加到其中的数据:list_key.append(key)/ list_key.pop():

    general_list = []
    def search_keys(dict1, list_key=[]):
        for key, value in dict1.items():
            list_key.append(key)
            if isinstance(value, dict):
                search_keys(value, list_key)
            elif isinstance(value, str):
                general_list.append(list_key.copy())
                # list_key.clear()                       # убрано
            list_key.pop()                               # добавлено
        return general_list
        
    print(search_keys(dict1))
    

    但一切都可以做得更简单。我们递归地浏览字典,形成列表。性能不是最好的,但是除非您的字典有数千个嵌套的深度,否则您不会知道有些事情很慢:

    def search(d):
        if isinstance(d, dict):
            for k, v in d.items():
                for lst in search(v):
                    yield [k] + lst
        else:
            yield []
    
    
    dict1 = {
        '1': {'2': {'3': 'text'},'4': {'5': {'6': 'text'},'7': 'text'}},
        '8': {'9': {'10': 'text'}}
    }
    for lst in search(dict1):
        print(lst)
    
    $ python search.py
    ['1', '2', '3']
    ['1', '4', '5', '6']
    ['1', '4', '7']
    ['8', '9', '10']
    

    如果您担心非常深的词典的性能,那么有一个更复杂的选项可以获得最佳性能。唯一的区别在于键列表的构建方式:以前它们是通过顺序连接(字典深度的每个平方)构建的,现在它们是在向下递归下降的过程中累积的(每行)。这个选项和你的很接近,相同的构建块以不同的方式连接:

    def search(d):
    
        def search(d, path):
            if isinstance(d, dict):
                for k, v in d.items():
                    path.append(k)
                    yield from search(v, path)
                    path.pop()
            else:
                yield path[:]
    
        return search(d, [])
    

    到目前为止,所有的解决方案都是递归的,也就是说,它们不会处理超过一千个字典嵌套。迭代解决方案将消除这一限制。stack存储嵌套字典上的迭代器。答案是path:

    def search(d):
        stack = [iter(d.items())]
        path = [None]
        while stack:
            for k, v in stack[-1]:
                path[-1] = k
                if isinstance(v, dict):
                    stack.append(iter(v.items()))
                    path.append(None)
                else:
                    yield path[:]
                break
            else:
                stack.pop()
                path.pop()
    
    • 2

相关问题

  • 是否可以以某种方式自定义 QTabWidget?

  • telebot.anihelper.ApiException 错误

  • Python。检查一个数字是否是 3 的幂。输出 无

  • 解析多个响应

  • 交换两个数组的元素,以便它们的新内容也反转

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    我看不懂措辞

    • 1 个回答
  • Marko Smith

    请求的模块“del”不提供名为“default”的导出

    • 3 个回答
  • Marko Smith

    "!+tab" 在 HTML 的 vs 代码中不起作用

    • 5 个回答
  • Marko Smith

    我正在尝试解决“猜词”的问题。Python

    • 2 个回答
  • Marko Smith

    可以使用哪些命令将当前指针移动到指定的提交而不更改工作目录中的文件?

    • 1 个回答
  • Marko Smith

    Python解析野莓

    • 1 个回答
  • Marko Smith

    问题:“警告:检查最新版本的 pip 时出错。”

    • 2 个回答
  • Marko Smith

    帮助编写一个用值填充变量的循环。解决这个问题

    • 2 个回答
  • Marko Smith

    尽管依赖数组为空,但在渲染上调用了 2 次 useEffect

    • 2 个回答
  • Marko Smith

    数据不通过 Telegram.WebApp.sendData 发送

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

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

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5