xml遍历

#coding=utf-8
#author:wsy
Date: 2019 / 9 / 19

Time: 13:57

tag:string对象,表示数据代表的种类,当为节点时为节点名称。

text:string对象,表示element的内容。

attrib:dictionary对象,表示附有的属性。

tail:string对象,表示element闭合之后的尾迹。

若干子元素(child elements)。

path=‘C:/Users/dell/Desktop/exl_file/’
try:
import xml.etree.cElementTree as ET
except ImportError:
import xml.etree.ElementTree as ET

1. 从文件中解析xml文件

tree = ET.ElementTree(file=path+‘doc.xml’) # 载入数据

root = tree.getroot() # 获取根节点

import 数据库连接 as ds

local_data=ds.data_souce()

2. 从内存字符串中解析xml

root = ET.fromstring(ds.data_souce())

import xml
import xml.etree.ElementTree as ET

“”"
实现从xml文件中读取数据
“”"

全局唯一标识

unique_id = 1

遍历所有的节点

def walkData(root_node, level, result_list):
global unique_id
temp_list = [unique_id, level, root_node.tag, root_node.attrib,root_node.text]
result_list.append(temp_list)
unique_id += 1

# 遍历每个子节点
children_node = root_node.getchildren()
if len(children_node) == 0:
    return
for child in children_node:
    walkData(child, level + 1, result_list)
return

def getXmlData(file_name):
level = 1 # 节点的深度从1开始
result_list = []
root = ET.parse(file_name).getroot()
walkData(root, level, result_list)

return result_list

if name == ‘main’:
# ‘d:\fenlei2.xml’
file_name = path+‘test_medical.xml’
R = getXmlData(file_name)
for x in R:
print(x)
在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值