python实现-从带层级的json到markdown无序列表的父子关系的转换

2023-10-27

从带层级的json到无序列表的父子关系的转换

首先,我们需要查看JSON数据结构,然后将它转换成Markdown序列列表格式。

为了实现这个目标,我们可以编写一个递归函数来处理层级关系。

假设我们的JSON结构如下:


{
  "name": "思维导图",
  "children": [
    {
      "name": "主题1",
      "children": [
        {
          "name": "子主题1.1"
        },
        {
          "name": "子主题1.2"
        }
      ]
    },
    {
      "name": "主题2",
      "children": [
        {
          "name": "子主题2.1"
        }
      ]
    }
  ]
}  

我们可以使用以下递归函数将其转换为Markdown序列列表:


import json


def json_to_markdown(json_data, depth=0):
    markdown_output = ''
    if 'name' in json_data:        
        markdown_output += '  ' * depth + '- ' + json_data['name'] + '\n'
    if 'children' in json_data:        
        for child in json_data['children']: 
            markdown_output += json_to_markdown(child, depth + 1)
    return markdown_output


json_string = '''上述的JSON内容'''
json_data = json.loads(json_string)
markdown_output = json_to_markdown(json_data)

print(markdown_output)  

输出的Markdown序列列表格式如下:


- 思维导图
    - 主题1
        - 子主题1.1
        - 子主题1.2
    - 主题2
        - 子主题2.1  

这样,我们就可以将博文中的JSON数据转换成Markdown序列列表了。注意,你需要将上述代码中的json_string替换为实际的JSON数据。

我现在想把json文本放到文件里面, 但是我这个json文本很长, 我应该如何加载到python中, 才不会栈溢出, 然后使用递归转换成markdown格式的文本

您可以使用以下方法将JSON文本加载到Python中:

  1. 将JSON数据存储在一个名为json_data.json的文件中。
  2. 使用with语句和open()函数打开文件并将内容读取到一个变量中。
  3. 使用json.loads()函数将JSON文本转换为Python字典。

例如:


import json

# 读取JSON文件内容  
with open('json_data.json', 'r', encoding='utf-8') as file:
    json_string = file.read()
# 将JSON文本转换为Python字典  
json_data = json.loads(json_string)


# 使用先前提供的递归函数将JSON数据转换为Markdown  
def json_to_markdown(json_data, depth=0):
    markdown_output = ''
    if 'name' in json_data:
        markdown_output += '  ' * depth + '- ' + json_data['name'] + '\n'
    if 'children' in json_data:
        for child in json_data['children']:
            markdown_output += json_to_markdown(child, depth + 1)
            return markdown_output
        # 转换并打印输出的Markdown  


markdown_output = json_to_markdown(json_data)
print(markdown_output)  

至于栈溢出的问题,Python具有递归深度限制,这可能会导致栈溢出。为了解决这个问题,您可以通过设置较高的递归深度来尝试优化。不过请注意,设置过高的递归深度可能会导致内存不足的问题。下面是如何更改递归深度限制的示例:


import sys  

# 设置递归深度限制  
sys.setrecursionlimit(3000)  

在运行递归函数之前,您可以将上述代码添加到脚本中以提高递归深度限制。这将有助于避免栈溢出问题。然而,如果您的JSON数据结构非常大且层次非常深,您可能需要使用非递归方法来处理这种情况。

最后输出成一个 markdown
在已经生成Markdown序列列表的基础上,我们可以将其保存到一个Markdown文件中。以下是将markdown_output保存到名为output.md
的文件中的代码:


#将Markdown输出保存到文件

with open('output.md', 'w', encoding='utf-8') as file:  
    file.write(markdown_output)

将此代码添加到之前的Python脚本中,您将会得到一个完整的脚本,该脚本可以读取JSON文件,将其转换为Markdown序列列表,并将结果保存到名为output.md
的文件中。以下是完整的脚本:


import json  
import sys  

#设置递归深度限制

sys.setrecursionlimit(3000)  

#读取JSON文件内容

with open('json_data.json', 'r', encoding='utf-8') as file:  
    json_string = file.read()  

#将JSON文本转换为Python字典

json_data = json.loads(json_string)  

#使用递归函数将JSON数据转换为Markdown

def json_to_markdown(json_data, depth=0):  
    markdown_output = ''    
    if 'name' in json_data:        
        markdown_output += '  ' * depth + '- ' + json_data['name'] + '\n'    
    if 'children' in json_data:        
        for child in json_data['children']:            
            markdown_output += json_to_markdown(child, depth + 1)    
            return markdown_output  

#转换并打印输出的Markdown

markdown_output = json_to_markdown(json_data)  
print(markdown_output)  

#将Markdown输出保存到文件

with open('output.md', 'w', encoding='utf-8') as file:  
    file.write(markdown_output)

运行此脚本后,您会在脚本所在的目录下找到一个名为output.md的Markdown文件,其中包含转换后的序列列表。

总结

with open(‘output.md’, ‘w’, encoding=‘utf-8’) as file:
file.write(markdown_output)

with open(‘json_data.json’, ‘r’, encoding=‘utf-8’) as file:
json_string = file.read()
这两句, 主要是我不懂这两句的语法

这两个代码段使用Python的with语句和open()函数分别打开和处理文件。让我逐行解释这些代码段。

  1. with open('output.md', 'w', encoding='utf-8') as file:

这一行使用with语句和open()函数打开名为output.md的文件。'w'参数表示我们要以写入模式(write
mode)打开文件。这意味着如果文件已经存在,我们将覆盖它;如果文件不存在,我们将创建一个新文件。encoding='utf-8'
指定了文件的字符编码。as file表示我们将在with语句的块中使用变量名file引用打开的文件对象。

  1. file.write(markdown_output)

with语句的块中,我们使用write()方法将markdown_output变量的内容写入到文件中。在这种情况下,markdown_output
包含了我们之前从JSON数据生成的Markdown序列列表。

  1. with open('json_data.json', 'r', encoding='utf-8') as file:

类似于第一行,这一行使用with语句和open()函数打开名为json_data.json的文件。但是,这次我们使用'r'参数表示我们要以读取模式(read
mode)打开文件。这意味着我们将从文件中读取内容,而不是写入内容。encoding='utf-8'同样指定了文件的字符编码。as file
表示我们将在with语句的块中使用变量名file引用打开的文件对象。

  1. json_string = file.read()

在这个with语句的块中,我们使用read()方法读取文件的内容,并将其存储在名为json_string
的变量中。这样,我们可以在后续的代码中处理这个字符串,例如使用json.loads()将其转换为Python字典。

with语句的一个重要特性是,在块结束时,它会自动关闭文件。这意味着您不需要显式地调用file.close()
方法。当处理文件时,这可以确保文件被正确关闭,并减少资源泄漏的风险。

python中 with的用法一定要跟 as 结合在一起吗, 顺便也说下 as 的用法吧

with语句在Python中用于设置运行时上下文。它通常与as关键字一起使用,但并不总是必须这样。当使用with
语句时,通常与实现了上下文管理协议(即具有__enter__()__exit__()方法)的对象一起使用。with
语句确保在块结束时调用__exit__()方法,从而实现自动资源管理。

as关键字在with语句中的作用是为返回的上下文对象分配一个变量名,使您能够在with块中引用它。这在处理文件或数据库连接等资源时非常有用。

让我们通过一个简单的示例来说明withas的用法:


with open('example.txt', 'r') as file:  
    content = file.read()    
    print(content)

在此示例中,with语句用于打开名为example.txt的文件。open()函数返回一个文件对象,我们使用as
关键字为该对象分配了一个变量名file。在with块中,我们可以使用这个变量名来调用文件对象的方法,例如read()。当with
块结束时,file对象的__exit__()方法将被自动调用,从而关闭文件。

虽然withas通常一起使用,但您可以在不使用as的情况下使用with语句。在这种情况下,您将无法在with
块中引用上下文对象。以下是一个不使用as关键字的示例:


class Context:  
    def __enter__(self):        
        print("Entering the context")            
    def __exit__(self, exc_type, exc_value, traceback):  
        print("Exiting the context")  
with Context():  
    print("Inside the context")

在这个例子中,我们创建了一个简单的上下文管理器类Context,它包含__enter__()__exit__()方法。当我们使用with
语句时,我们不使用as关键字。因此,在with块中,我们无法引用Context对象。在这种情况下,with
仅确保在块结束时调用__exit__()方法。

总之,withas关键字通常一起使用,以便在with块中引用上下文对象。然而,as
关键字并不是必需的,您可以选择不使用它,但在这种情况下,您将无法在with块中引用上下文对象。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

python实现-从带层级的json到markdown无序列表的父子关系的转换 的相关文章

随机推荐

  • SpringCloud微服务实战——搭建企业级开发框架(四十二):集成分布式任务调度平台XXL-JOB,实现定时任务功能

    定时任务几乎是每个业务系统必不可少的功能 计算到期时间 过期时间等 定时触发某项任务操作 在使用单体应用时 基本使用Spring提供的注解即可实现定时任务 而在使用微服务集群时 这种方式就要考虑添加分布式锁来防止多个微服务同时运行定时任务而
  • java 找不到方法_Java程序找不到主方法,在哪里加上呢

    importjava awt FlowLayout importjava awt event ActionListener importjava awt event ActionEvent importjavax swing JFrame
  • from tensorflow.examples.tutorials.mnist import input_data 出错

    在使用tensorflow实现辨别手写体的过程中遇到了一下错误 那么你则可以看下你当前环境下的TensorFlow的example中是否有tutorials文件或是否有example文件夹 进入后如果发现 没有则去tensorflow中进行
  • 用网线实现两台电脑之间的文件共享

    配置步骤 将一根网线分别插入两台电脑的网口 这个 没什么要说的吧 配置电脑IP 假设我们现在有两台电脑A B 我们想把电脑A上的某个文件或者文件夹共享到电脑B上 我们首先修改A的IP为192 168 0 1 如下图所示 同样的方法将电脑B的
  • cuda/cudnn/cuda 10.1安装教程

    方法1 NVIDIA 显卡驱动安装示例 ubuntu系统刚装好 推荐 Ubuntu 18 04 安装 NVIDIA 显卡驱动 ps 1 新系统的签名要重新注册 2 要禁用nouveau 新安装方法 其他参考 https zhuanlan z
  • windows安装jdk1.8并配置环境变量

    1 首先我们到官网 https www oracle com java technologies javase javase jdk8 downloads html下载安装包 提示要登录甲骨文账号 没有的话注册一个就好了 2 下载完成 我们
  • Hosting custom WPF calendar control in AX 2012

    原作者 https community dynamics com ax b axilicious archive 2013 05 20 hosting custom wpf calendar control in ax 2012 aspx
  • alter database 与 alter system的区别

    这两天一直在看oracle的教材 对于alter system和alter database的使用场合比较模糊 其实 在我的第一篇日记里边写了实例名 数据库名的区别 这两个命令区别就是做用范围的不同 alter database 主要是和数
  • k8s-工作负载组件理解

    先来段官方语言压压惊 工作负载是在 Kubernetes 上运行的应用程序 无论你的负载是单一组件还是由多个一同工作的组件构成 在 Kubernetes 中你 可以在一组 Pods 中运行它 在 Kubernetes 中 Pod 代表的是集
  • Flutter 返回键监听,提示再按一次退出app

    Flutter 返回键监听 提示再按一次退出app 直接贴代码 override Widget build BuildContext context return AnnotatedRegion
  • 服务器清理c盘日志文件,清理WIN2003服务器C盘垃圾的批处理

    保存为OOXX bat 然后运行即可 脚本会清理c盘下的日志 如有重要日志请先自行备份 ECHO OFF echo echo echo 清理几个比较多垃圾文件的地方 DEL F S Q C WINDOWS PCHealth ERRORREP
  • Python selenium 模拟操作下拉框

    学习笔记 from selenium import webdriver from selenium webdriver common by import By import time from selenium webdriver impo
  • B - Derangement

    题目链接 题解 用最少的改变两个数的位置使得a i i 题解 很简单 但是注意细节 下面试rte 2 的代码 include
  • 基础知识: HP-Unix下Oracle9i的安装

    基础知识 HP Unix下Oracle9i的安装 一 作为root用户的工作 1 配置内核参数 用root用户登陆 sam 进入system administrator manager 在其中选择kernel configuration 进
  • qt: exec()的用法,accept()和accepted的概念

    转载 http blog csdn net xdlichen article details 46374517 本篇 会重点讲述模式对话框 以及exec 的用法 accept 和accepted的概念 一 非模式对话框 非模式对话框是和同一
  • STM32-HAL 学习-TIM输入捕获-07

    1 时钟配置如前面 2 定时器输入捕获通道一设置 3 主函数 注意开启定时器中断 uint16 t capture 0 uint8 t End status 0 uint16 t Cap Timer 0 uint32 t H Timer 0
  • 刨根问底struts2

    MVC一探究竟之struts2 最近一直在学习JAVAEE中的MVC框架的一些知识 笔者写这篇博客的目的是想系统的对struts2一些核心使用的东西做一个总结 在myeclipse中构建好struts2框架之后 web容器当中的配置文件we
  • Keepalived 配置手册

    官网 https www keepalived org manpage html 1 描述 keepalived conf 是描述所有Keepalived关键字的配置文件 关键字放在块和子块的层次结构中 每一层由 和 对分隔 注释以 或 到
  • 目标检测中的回归损失函数系列二:IoU Loss

    IOU Loss 出自论文 https arxiv org pdf 1608 01471 pdf L1 和L2 loss是将bbox四个点分别求loss然后相加 并没有考虑靠坐标之间的相关性 而实际评价指标IOU是具备相关性 看一张图关注I
  • python实现-从带层级的json到markdown无序列表的父子关系的转换

    带层级的json到无序列表的父子关系的转换 从带层级的json到无序列表的父子关系的转换 总结 python中 with的用法一定要跟 as 结合在一起吗 顺便也说下 as 的用法吧 从带层级的json到无序列表的父子关系的转换 首先 我们