首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何从Python中的嵌套字典中创建一个引导手风琴?

如何从Python中的嵌套字典中创建一个引导手风琴?
EN

Stack Overflow用户
提问于 2020-09-03 22:35:30
回答 1查看 1.1K关注 0票数 0

我有一本类似于此的嵌套字典:

代码语言:javascript
复制
d = {1: {4: {6: {}, 7: {}, 8: {}}, 5: {}}, 2: {}, 3: {}}

可以将其可视化为:

代码语言:javascript
复制
1
    4
       6
       7
       8
    5
2
3

我的目标是创建一个引导手风琴,就像下面的链接:https://codepen.io/glebkema/pen/QQOZRe?editors=1000

这里有一个截图:

为了实现我的目标,我想我可以在python脚本中生成html代码,该脚本可以使用烧瓶进行渲染。我想出的代码是:

代码语言:javascript
复制
def pretty(d, indent=0, indent_before=0):
    html_code = ''
    for key, value in d.items():
            
        if indent > indent_before:
            html_code += """
            <div id="collapse-1-1" class="collapse" data-parent="#accordion-1" aria-labelledby="heading-1-1">
                    <div class="card-body">
                    <div id="accordion-1-1">
            """
        elif indent == indent_before:
            html_code += """
            </div>
            """
        else:
            html_code += """
            </div>
            """*indent

        html_code +="""
            <div class="card">
                <div class="card-header" id="heading-{}">
                    <h5 class="mb-0">
                    <a role="button" data-toggle="collapse" href="#collapse-{}" aria-expanded="false" aria-controls="collapse-{}">
                            {}
                    </a>
                    </h5>
                </div>
        """.format(key ,key, key, key, indent)
        #print('\t' * (indent) + str(key) + '({})({})\n'.format(indent,indent_before))
        if isinstance(value, dict):
            html_code  += pretty(value, indent+1, indent) 
        else:
            print('\t' * (indent+1) + str(value))

    return html_code
        
msg = pretty(result)
print(msg)

基本上,它是一个递归函数,它遍历所有字典项。但是,这段代码有3个度量错误,我不知道如何修复:

  • 手风琴引用并不是每次添加新层时都会更改,而是在每个项目
  • 之前添加
  • A class=“折叠”div,因为我无法正确关闭div,因为我无法跟踪每个级别添加了多少项。

我得到的输出如下:

代码语言:javascript
复制
<div class="card">
                <div class="card-header" id="heading-1">
                    <h5 class="mb-0">
                    <a role="button" data-toggle="collapse" href="#collapse-1" aria-expanded="false" aria-controls="collapse-1">
                            1
                    </a>
                    </h5>
                </div>

            <div id="collapse-1-1" class="collapse" data-parent="#accordion-1" aria-labelledby="heading-1-1">
                    <div class="card-body">
                    <div id="accordion-1-1">

            <div class="card">
                <div class="card-header" id="heading-4">
                    <h5 class="mb-0">
                    <a role="button" data-toggle="collapse" href="#collapse-4" aria-expanded="false" aria-controls="collapse-4">
                            4
                    </a>
                    </h5>
                </div>

            <div id="collapse-1-1" class="collapse" data-parent="#accordion-1" aria-labelledby="heading-1-1">
                    <div class="card-body">
                    <div id="accordion-1-1">

            <div class="card">
                <div class="card-header" id="heading-6">
                    <h5 class="mb-0">
                    <a role="button" data-toggle="collapse" href="#collapse-6" aria-expanded="false" aria-controls="collapse-6">
                            6
                    </a>
                    </h5>
                </div>

            <div id="collapse-1-1" class="collapse" data-parent="#accordion-1" aria-labelledby="heading-1-1">
                    <div class="card-body">
                    <div id="accordion-1-1">

            <div class="card">
                <div class="card-header" id="heading-7">
                    <h5 class="mb-0">
                    <a role="button" data-toggle="collapse" href="#collapse-7" aria-expanded="false" aria-controls="collapse-7">
                            7
                    </a>
                    </h5>
                </div>

            <div id="collapse-1-1" class="collapse" data-parent="#accordion-1" aria-labelledby="heading-1-1">
                    <div class="card-body">
                    <div id="accordion-1-1">

            <div class="card">
                <div class="card-header" id="heading-8">
                    <h5 class="mb-0">
                    <a role="button" data-toggle="collapse" href="#collapse-8" aria-expanded="false" aria-controls="collapse-8">
                            8
                    </a>
                    </h5>
                </div>

            <div id="collapse-1-1" class="collapse" data-parent="#accordion-1" aria-labelledby="heading-1-1">
                    <div class="card-body">
                    <div id="accordion-1-1">

            <div class="card">
                <div class="card-header" id="heading-5">
                    <h5 class="mb-0">
                    <a role="button" data-toggle="collapse" href="#collapse-5" aria-expanded="false" aria-controls="collapse-5">
                            5
                    </a>
                    </h5>
                </div>

            </div>

            <div class="card">
                <div class="card-header" id="heading-2">
                    <h5 class="mb-0">
                    <a role="button" data-toggle="collapse" href="#collapse-2" aria-expanded="false" aria-controls="collapse-2">
                            2
                    </a>
                    </h5>
                </div>

            </div>

            <div class="card">
                <div class="card-header" id="heading-3">
                    <h5 class="mb-0">
                    <a role="button" data-toggle="collapse" href="#collapse-3" aria-expanded="false" aria-controls="collapse-3">
                            3
                    </a>
                    </h5>
                </div>

你能提出一种聪明而优雅的方法从字典开始生成手风琴吗?只要我得到我可以呈现的html代码,您就可以随意修改代码。我也考虑过使用Jinja2,但我对此一无所知。提前谢谢。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-09-11 11:29:21

我能够在我真正的问题上达到我的结果。以下是代码:

代码语言:javascript
复制
def pretty(d, indent=0, indent_previous_layer=-1, counter=0):
    html_code = ''
    indent_privious_item = indent_previous_layer
    for key, value in d.items():             
            
        if indent > indent_privious_item and counter!=0:
            html_code += """
            <div id="collapse-{}" class="collapse" data-parent="#accordion-{}" aria-labelledby="heading-{}">
            <div class="card-body">
                <div id="accordion-{}">
            """.format(counter, indent-1, counter, indent)
        elif indent == indent_privious_item:
            html_code += """
            </div>
            """
            if indent==0:
                html_code += """
                <!--End of Card-->
                """
        elif indent < indent_privious_item:
            if indent==0:
                html_code += """
                                </div>
                """
                html_code += """
                            </div>
                        </div>
                    </div>
                </div>
                """*(indent_privious_item-indent)
                html_code += """
                <!--End of Card-->
                """
            else:
                html_code += """
                                </div>
                """
                html_code += """
                            </div>
                        </div>
                    </div>
                </div>
                """*(indent_privious_item-indent)

        html_code +="""
        <div class="card">
        <div class="card-header" id="heading-{}">
            <h5 class="mb-0">
                <a role="button" data-toggle="collapse" href="#collapse-{}" aria-expanded="true" aria-controls="collapse-{}">
                 Depth Level {}
                </a>
            </h5>
        </div>
            <div class="card-body pb-0">
                <!--h5 class="card-title"></h5-->
                <p class="card-text">{}</p>
                    <ul class="list-group">""".format(counter+1, counter+1, counter+1, indent, "Some text")

        html_code += """
                    </ul>
            </div>
    
            """

        if isinstance(value, dict):
            code, indent_privious_item, counter = pretty(value, indent+1, indent, counter+1)
            html_code += code
        else:
            print('\t' * (indent+1) + str(value))
        
    return html_code, indent_privious_item, counter

注:压痕可能消失。你可以随意修理

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/63732522

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档