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

首頁 > 編程 > Python > 正文

python比較2個xml內容的方法

2020-02-23 01:11:30
字體:
來源:轉載
供稿:網友

本文實例講述了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程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 晋宁县| 开封县| 元阳县| 桑日县| 广水市| 五寨县| 牟定县| 长宁县| 体育| 磐安县| 祁东县| 汉中市| 永昌县| 桃江县| 通州市| 江油市| 大名县| 腾冲县| 通河县| 湛江市| 义乌市| 广宁县| 龙陵县| 太仆寺旗| 湘潭市| 陆丰市| 巩义市| 德清县| 英吉沙县| 靖远县| 宁蒗| 吴堡县| 雷州市| 安义县| 三河市| 鄂伦春自治旗| 仪陇县| 陈巴尔虎旗| 萝北县| 云霄县| 宜黄县|