国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

python比較2個xml內容的方法

2019-11-25 17:29:38
字體:
來源:轉載
供稿:網友

本文實例講述了python比較2個xml內容的方法。分享給大家供大家參考。具體分析如下:

from xml.etree import ElementTree OK=True main_pid = 10000 loop_depth = 0 def compare_xml(left, right, key_info='.'):  global loop_depth   loop_depth += 1   if loop_depth == 1: print   if left.tag != right.tag:     print_diff(main_pid, key_info, 'difftag', left.tag, right.tag)    return   if left.text != right.text:     print_diff(main_pid, key_info, 'difftext', left.text, right.text)    return   leftitems = dict(left.items())   rightitems = dict(right.items())   for k,v in leftitems.items():     if k not in rightitems:       s = '%s/%s' % (key_info, left.tag)       print_diff(main_pid, s, 'lostattr', k, "")  for k,v in rightitems.items():     if k not in leftitems:       s = '%s/%s' % (key_info, right.tag)       print_diff(main_pid, s, 'extraattr', "", k)  leftnodes = left.getchildren()   rightnodes = right.getchildren()   leftlen = len(leftnodes)   rightlen = len(rightnodes)   if leftlen != rightlen:     s = '%s/%s' % (key_info, right.tag)    print_diff(main_pid, s, 'difflen', leftlen, rightlen)    return   l = leftlen<rightlen and leftlen or rightlen  d = {}   for i in xrange(l):         node=leftnodes[i]     if node.tag not in d:       d[node.tag] = 1       tag = node.tag     else:       tag = node.tag + str(d[node.tag])      d[node.tag] += 1     s = '%s/%s' % (key_info, tag)     compare_xml(leftnodes[i], rightnodes[i], s)def print_diff(main_pid, key_info, msg, base_type, test_type):  global OK   info = u'[ %-5s ] %s -> %-40s [ %s != %s ]'%(msg.upper(), main_pid, key_info.strip('./'), base_type, test_type)  print info.encode('gbk')  OK = False

調用:

if __name__ == '__main__':   s1 = '''''<?xml version="1.0" encoding="UTF-8"?> /     <employees> /      <employee id = '1'> /       <name>linux</name>/       <age>30</age>/      </employee>/      <employee id = '2'> /       <name>windows</name>/       <age>20</age>/      </employee>/      </employees>'''    s2 = '''''<?xml version="1.0" encoding="UTF-8"?> /     <employees> /      <employee id = '3'> /       <name>windows</name>/       <age>20</age>/      </employee>/      <employee id = '4'> /       <name>linux</name>/       <age>30</age>/      </employee>/      </employees>'''    lroot = ElementTree.fromstring(s1)   rroot = ElementTree.fromstring(s2)   compare_xml(lroot, rroot)

希望本文所述對大家的Python程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 闽侯县| 上饶市| 蛟河市| 剑河县| 仁怀市| 三台县| 镇坪县| 东方市| 安陆市| 清丰县| 渑池县| 南岸区| 克拉玛依市| 无锡市| 尉氏县| 社会| 扶风县| 五家渠市| 连云港市| 阿拉善左旗| 丰台区| 蒙阴县| 镇沅| 尉犁县| 娄烦县| 义乌市| 石台县| 夹江县| 延津县| 遵化市| 措勤县| 淮南市| 余干县| 浠水县| 家居| 五常市| 黑龙江省| 惠水县| 巨野县| 徐州市| 安龙县|