代码拉取完成,页面将自动刷新
import UniversalParser as UP
from UniversalParser import SM
from UniversalParser import TextType
xml_data = """
<root>
<a name="name_a">I am A.</a>
<b name="name_b">
<c name="name_c" flag="1">I am C.</c>
<c name="name_$c" flag="1">I am CC.</c>
<c>666</c>
<c>hello</c>
<c>
<d name="d">world</d>
123
<e name="e"></e>
567
<hh></hh>
<hh></hh>
</c>
</b>
</root>
"""
# xmlManager = xmltocd.parse('output.xml')
xmlManager = UP.parse_xml(xml_data, analysis_text=False, namespace_separator='', cdata_separator=' ')
# xmlManager = UP.parse_xml(xml_data, analysis_text=False)
xml = xmlManager.xml # 获取整个XML对象
root = xml.root # 取根节点
# import json
# print(json.dumps(xmlManager.objects.doc, indent=4))
# print(json.dumps(xmlManager.xml, indent=4))
print(root.b.c[-1].d.text_) # world
# print(root.b.c[-1].d & SM.text)
# print(root.b.c[-1].d & SM.attr_names)
# print(root.b.c[-1].d & SM.tag)
# print(root.b.c[-1].d & SM.ancestor)
# print(root.b.c[-1].d & SM.descendants)
# print(root.b.c[-1].d & SM.siblings)
# print(root.b.c[-1].d & SM.children)
# print(root.b.c[-1].d & SM.parent)
# 取属性值
print(root.a.name) # name_a
print(root.a['name']) # name_a
# 取文本
print(root.a.text_) # I am A.
print(root.a['text_']) # I am A.
print(root.b.c[0].text_) # I am C.
print(root.b.c[3].text_) # hello
xmlManager.insert_attrs(root.b.c[3], flag="123456")
print(root.b.c[-1].d.text_) # world
print(root.b.c[-1].text_) # 123
print(xmlManager.find_text(root.b.c[-2])) # hello
'''
text_type可选值:TextType.STR、TextType.FLOAT、TextType.INT。默认 STR 类型。
'''
print(xmlManager.find_text_by_attrs(text_type=TextType.STR, name="d")) # world
# 更新属性/文本值
root['a'].age = 12 # 不可取,必须使用本工具提供的方法新增节点,否则程序不会认为 age 是属性值(因为保存操作有反转数据操作)
xmlManager.objects.signal_add_attr_base(root['a'], 'age', 12) # 如果一定要用上面的新增属性方式,则必须注册,以让程序了解到属性地更新(后期考虑自动感知)
root['a'].age = 12
# xmlManager.objects.signal_add_attr_base(root['a'], 'age', 12) # 无效注册,仅需手动注册一次
# 建议使用如下方式新增属性
xmlManager.insert_attrs(root['a'], ('age', 12))
xmlManager.insert_attrs(root['a'], ('age', 14)) # 重复添加,仅第一个有效
node_a = xmlManager.find_node_by_attrs(name="name_a")
xmlManager.update_attr(node_a, 'age', 45)
xmlManager.batch_update_attrs(node_a, ('age', 100), age=123) # 接收位置参数和关键字参数,重复时后者覆盖前者
# xmlManager.update_text(node_a, 'I am A2.') # 默认存在,若是新增节点请使用 first = True
# xmlManager.update_text(root.b.c[4].e, 'I am e.')
print(node_a) # ChainDict([('name', 'name_a'), ('text_', 'I am A2.'), ('age', 123)])
# 推荐使用下面的方式创建并插入一个 f 节点
xmlManager.insert(root.b.c[4].e, tag='f', attrs={'name': "name_f"}, text='I am f.')
### 通过属性获取节点对象
# 取唯一的节点(必须只有一个,否则报 MoreNodesFound 和 NoNodesFound 异常)
name_c = xmlManager.find_nodes_by_attrs(name='name_$c', flag="1", one_=True)
print(name_c.text_) # I am CC.
# 取满足条件的多个节点,当节点一个也不存在时报 NoNodesFound 异常
cs = xmlManager.find_nodes_by_attrs(flag="1")
print(cs) # [ChainDict([('name', 'name_c'), ('flag', '1'), ('text_', 'I am C.')]), ChainDict([('name', 'name_$c'), ('flag', '1'), ('text_', 'I am CC.')])]
# 取满足条件的且为指定索引位置的几个节点,如果索引不存在,则返回空迭代器
c = xmlManager.find_nodes_by_indexs([0, 18, 3], flag="1") # 取第一个
print(list(c)) # [ChainDict([('name', 'name_c'), ('flag', '1'), ('text_', 'I am C.')])]
print(xmlManager.find_nodes_by_attrs(name='name_c', one_=True).text_)
objs = xmlManager.find_nodes_by_tag_and_attrs(tag_="c", name='name_$c')
print(objs)
# 删除
xmlManager.pop_nodes_by_attrs(name="e")
# 保存修改
xmlManager.save_as_xml('output.xml')
xmlManager.save_as_json()
# print(xmlManager.get_xml_data())
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。