python解析xml文件增删查找

python解析xml文件增删查找

XML文件

在这里插入图片描述

判断bndbox大小,并为object添加子节点difficult

#!/usr/bin/env python
# -*- coding:utf-8 -*-

import os
import os.path
from xml.etree import ElementTree as ET

path='C:/Users/my/Desktop/xmllll/city/1'
new_path='C:/Users/my/Desktop/xmllll/city/1/'
files=os.listdir(path) #得到文件夹下所有文件名称
my_area = int(input("请输入area区域大小:"))
# my_area = 20
for xmlFile in files: #遍历文件夹
    if not os.path.isdir(xmlFile): #判断是否是文件夹,不是文件夹才打开
        print(xmlFile)
        per = ET.parse(new_path + xmlFile)
        p=per.findall('./object')
        number_name = 0
        area = []
        # print(type(my_area))
        for oneper in p:  #找出object节点
            for child in oneper.getchildren(): #找出object节点的子节点bndbox/name
                for grandson in child.getchildren(): #找出bndbox节点的子节点
                    area.append(int(child.find('xmin').text))
                    area.append(int(child.find('ymin').text))
                    area.append(int(child.find('xmax').text))
                    area.append(int(child.find('ymax').text))
                    if len(area) == 4:
                        element = ET.Element("difficult")  
                        if ((area[2]-area[0]) > my_area) & ((area[3]-area[1])> my_area):
                                element.text = "0"
                        else:
                                element.text = "1"
                        oneper.insert(1,element)
                        per.write(new_path + xmlFile, encoding="utf-8",xml_declaration=True)
                    area.clear()
                    break
        print('-------')

  1. 该文件可以批处理xml文件
  2. 可以添加子节点,索引
  3. 但是存在速度问题,一直没法提高速度,应该和使用了大量for循环有关
  4. 注意:修改的xml文件是缓存在内存当中的,因此一定要保存
  5. 添加子节点可以用append或者insert,指定位置用insert

Result

在这里插入图片描述

xml增删查找

# -*- coding: utf-8 -*-
"""
Created on Mon Mar 18 17:36:45 2019
@author: psqk
"""
#!/usr/bin/env python
# -*- coding: utf8 -*-

from xml.etree import ElementTree
from xml.etree.ElementTree import Element, SubElement
from lxml import etree
import codecs

XML_EXT = '.xml'
ENCODE_METHOD = 'utf-8'

class PascalVocWriter:

    def __init__(self, foldername, filename, imgSize,databaseSrc='Unknown', localImgPath=None):
        self.foldername = foldername
        self.filename = filename
        self.databaseSrc = databaseSrc
        self.imgSize = imgSize
        self.boxlist = []
        self.localImgPath = localImgPath
        self.verified = False

    def prettify(self, elem):
        """
            Return a pretty-printed XML string for the Element.
        """
        rough_string = ElementTree.tostring
  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
### 回答1: Python中有许多用于解析XML文件的库,其中最常用的是内置的ElementTree模块。下面是一个基本的XML解析示例: 假设有一个名为“example.xml”的XML文件,其中包含以下内容: ```xml <?xml version="1.0" encoding="UTF-8"?> <root> <person> <name>John</name> <age>30</age> </person> <person> <name>Jane</name> <age>25</age> </person> </root> ``` 要解析文件,请使用以下代码: ```python import xml.etree.ElementTree as ET # 加载XML文件 tree = ET.parse('example.xml') # 获取根元素 root = tree.getroot() # 遍历所有person元素 for person in root.findall('person'): # 获取名称和年龄子元素 name = person.find('name').text age = person.find('age').text # 打印结果 print('Name: {}, Age: {}'.format(name, age)) ``` 运行此代码将输出: ``` Name: John, Age: 30 Name: Jane, Age: 25 ``` 在这个示例中,我们使用ElementTree库加载XML文件并获取根元素。然后我们使用`findall()`方法查找所有名为“person”的元素,并使用`find()`方法获取每个元素的子元素。最后,我们打印每个人的名称和年龄。 ### 回答2: 在Python中,我们可以使用内置的xml库来解析xml文件。首先,我们需要导入xml.etree.ElementTree模块,并使用其中的ElementTree类。 有两种常用的解析方式:DOM(文档对象模型)和SAX(简单API for XML)。DOM方式将整个xml文件加载到内存中,并以树形结构存储,可以方便地对节点进行修改。而SAX方式则是一种流式解析,逐个读取xml文件的节点并触发相应的事件。 下面是使用DOM方式解析xml文件的示例代码: ``` import xml.etree.ElementTree as ET tree = ET.parse('example.xml') # 解析xml文件 root = tree.getroot() # 获取根节点 # 遍历根节点下的所有子节点 for child in root: print(child.tag, child.attrib) # 打印节点的标签和属性 for subchild in child: print(subchild.tag, subchild.text) # 打印子节点的标签和文本内容 ``` 上述代码中的'example.xml'是xml文件的路径,可以根据实际情况进行替换。通过parse函数解析xml文件,然后使用getroot方法获取根节点。接着可以使用遍历等操作对节点进行处理,例如打印节点的标签和属性信息。 如果使用SAX方式解析xml文件,可以使用xml.sax模块中的handler类。首先需要定义一个名为ContentHandler的类,并重写其startElement、endElement和characters等方法。然后使用xml.sax.parse函数将xml文件和ContentHandler实例作为参数进行解析。 这是一个使用SAX方式解析xml文件的示例代码: ``` import xml.sax class MyHandler(xml.sax.ContentHandler): def startElement(self, name, attrs): print(name, attrs) # 打印节点的标签和属性 def characters(self, content): print(content) # 打印节点的文本内容 def endElement(self, name): pass xml.sax.parse('example.xml', MyHandler()) # 解析xml文件 ``` 同样,'example.xml'是xml文件的路径,可以替换为实际的文件路径。在MyHandler类中,我们可以根据需要重写startElement、endElement和characters等方法来处理不同的节点。 无论是DOM方式还是SAX方式,我们都可以根据具体需求选择合适的解析方式来解析xml文件。 ### 回答3: 在Python中,我们可以使用内置的`xml`模块来解析XML文件。 首先,我们需要导入`xml.etree.ElementTree`模块,并使用`ElementTree.parse()`函数来打开和解析XML文件。这个函数会返回一个`ElementTree`对象,我们可以使用它来获取XML文档的根元素。 接下来,我们可以使用`Element`对象的一些方法来获取和处理XML文档中的元素。例如,使用`Element.findall()`方法可以查找指定标签名的所有元素,使用`Element.find()`方法可以查找第一个匹配指定标签名的元素,使用`Element.text`属性可以获取元素的文本内容。 此外,我们还可以使用XPath表达式来选择特定的元素。可以通过`ElementTree`对象的`ElementTree.xpath()`方法或`Element`对象的`Element.findall()`方法来执行XPath查询。 下面是一个简单的示例,演示了如何使用Python解析XML文件: ```python import xml.etree.ElementTree as ET # 打开XML文件解析 tree = ET.parse('example.xml') root = tree.getroot() # 获取根元素的标签名和属性 print("根元素:", root.tag) print("根元素属性:", root.attrib) # 遍历子元素并获取它们的标签名和文本内容 for child in root: print("子元素:", child.tag, child.text) # 使用XPath表达式查找指定元素 elements = root.findall(".//book[author='John Smith']") for element in elements: print("查找结果:", element.tag, element.attrib) ``` 请注意,解析XML文件时需要注意文件路径是否正确。另外,XML文件应该格式正确,否则可能会导致解析错误。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值