如何使用python的xml库实现自闭合标签

 更新时间:2025年01月07日 10:00:59   作者:knighthood2001  
文章介绍了作者编写一个URDF格式化插件的初衷,目的是解决sw2urdf导出的URDF文件格式混乱的问题,本文结合实例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧

前言

最近一段时间一直想要写一个urdf格式化插件。

至于为什么嘛,因为使用sw2urdf插件,导出的urdf,同一标签的内容,是跨行的,这就导致,内容比较乱,而且行数比较多。影响阅读。

因此,自己想写格式化的脚本。

最近就开始分享一些,之前的思考。

正文

import xml.etree.ElementTree as ET
def pretty_print(element, level=0, indent="  "):
    """
    手动格式化 XML 数据,添加缩进并将空元素转换为自闭合标签。
    :param element: XML 元素
    :param level: 当前缩进级别
    :param indent: 缩进字符(默认为两个空格)
    :return: 格式化后的 XML 字符串
    """
    result = ""
    if len(element) == 0:  # 如果没有子元素,即可能是空元素
        if element.text and element.text.strip():  # 如果有文本内容
            result += f"{indent * level}<{element.tag}>{element.text.strip()}</{element.tag}>\n"
        else:
            result += f"{indent * level}<{element.tag} "
            # 如果有属性,添加到标签中
            if element.attrib:
                result += " ".join([f'{key}="{value}"' for key, value in element.attrib.items()])
            result += " />\n"  # 使用自闭合标签形式
    else:
        result += f"{indent * level}<{element.tag}"
        # 如果有属性,添加到标签中
        if element.attrib:
            result += " " + " ".join([f'{key}="{value}"' for key, value in element.attrib.items()])
        result += ">\n"
        # 处理元素的文本内容
        if element.text and element.text.strip():
            result += f"{indent * (level + 1)}{element.text.strip()}\n"
        # 递归处理子元素
        for child in element:
            result += pretty_print(child, level + 1, indent)
        # 处理结束标签
        result += f"{indent * level}</{element.tag}>\n"
    return result
# 读取 XML 文件
file_path = 'test.urdf'  # 请将此路径替换为实际的文件路径
tree = ET.parse(file_path)
root = tree.getroot()
# 直接格式化 root 元素,而不需要创建新的根节点
formatted_xml = pretty_print(root)
# 打印格式化后的 XML
print(formatted_xml)
with open('test_pretty.urdf', 'w') as f:
    f.write(formatted_xml)

这里,代码主要是通过xml.etree.ElementTree解析xml文件。

然后在函数中补充上空格,</>等标签。

注意,这个函数是个递归的函数,会在函数内部调用函数本身。

实现的效果如下

可以发现,目前的问题是:

  • 没有注释
  • urdf最开始的标签,不见了。

到此这篇关于使用python的xml库实现自闭合标签的文章就介绍到这了,更多相关python xml库自闭合标签内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 使用Python清空特定路径下所有文件夹下中的文件

    使用Python清空特定路径下所有文件夹下中的文件

    这篇文章主要为大家详细介绍了如何使用python清空特定路径下所有文件夹下中的文件并把空文件夹要保留下来,感兴趣的小伙伴可以跟随小编一起学习一下
    2025-01-01
  • Python自己定义一个求累加和的函数方式

    Python自己定义一个求累加和的函数方式

    定义了一个函数来计算不确定数量参数的累加和,使用`*args`来接收不定数量的位置参数,函数内部通过遍历`args`并使用`sum()`函数计算所有参数的累加和,运行结果是累加和的值
    2025-11-11
  • PyTorch Distributed Data Parallel使用详解

    PyTorch Distributed Data Parallel使用详解

    这篇文章主要为大家介绍了PyTorch Distributed Data Parallel使用详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-03-03
  • Python实现图像增强

    Python实现图像增强

    这篇文章主要为大家详细介绍了Python实现图像增强,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-08-08
  • 轻松掌握python设计模式之访问者模式

    轻松掌握python设计模式之访问者模式

    这篇文章主要帮助大家轻松掌握python设计模式之访问者模式,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-11-11
  • 利用OpenCV给彩色图像添加椒盐噪声的方法

    利用OpenCV给彩色图像添加椒盐噪声的方法

    椒盐噪声是数字图像中的常见噪声,一般是图像传感器、传输信道及解码处理等产生的黑白相间的亮暗点噪声,椒盐噪声常由图像切割产生,这篇文章主要给大家介绍了关于利用OpenCV给彩色图像添加椒盐噪声的相关资料,需要的朋友可以参考下
    2021-10-10
  • 在 Django/Flask 开发服务器上使用 HTTPS

    在 Django/Flask 开发服务器上使用 HTTPS

    使用 Django 或 Flask 这种框架开发 web app 的时候一般都会用内建服务器开发和调试程序,等程序完成后再移交到生产环境部署。问题是这些内建服务器通常都不支持 HTTPS,那么我们来探讨下开启https吧
    2014-07-07
  • 使用IPython来操作Docker容器的入门指引

    使用IPython来操作Docker容器的入门指引

    这篇文章主要介绍了使用IPython来操作Docker容器的方法,包括一些基本的搭建和连接,主要依靠docker-py模块,需要的朋友可以参考下
    2015-04-04
  • Python中的模式匹配库Pampy使用实例解析

    Python中的模式匹配库Pampy使用实例解析

    这篇文章主要为大家介绍了Python中的模式匹配库Pampy使用实例解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2024-01-01
  • Python jiaba库的使用详解

    Python jiaba库的使用详解

    这篇文章主要为大家介绍了Python jiaba库的使用,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助,希望能够给你带来帮助
    2021-11-11

最新评论