解析gbk格式帶中文的xml


方案

       1、以gbk格式讀取xml文件為字符串,替換xml聲明為utf-8格式

       2、將字符串編碼成utf-8格式,直接解析

 

代碼

 1 def parse_xml_node(node):
 2     if len(node.getchildren()) == 0:
 3         return node.text if node.text is not None else ''
 4     else:
 5         node_dict = {}
 6         for child in node.getchildren():
 7             if child.tag in node_dict.keys():
 8                 if not isinstance(node_dict[child.tag], list):
 9                     node_dict[child.tag] = [node_dict[child.tag]]
10                 node_dict[child.tag].append(parse_xml_node(child))
11             else:
12                 node_dict[child.tag] = parse_xml_node(child)
13         return node_dict
14 
15 def parse_gbk_xml(filename):
16     import codecs
17     from xml.etree import ElementTree
18     with codecs.open(filename,'r',encoding='gbk') as fp:
19         text = fp.read().replace('<?xml version="1.0" encoding="GBK"?>', '<?xml version="1.0" encoding="UTF-8"?>')
20     xdata = {}
21     element = ElementTree.fromstring(text.encode('utf-8'))
22     xdata[element.tag] = parse_xml_node(element)

 

結果驗證:

 1 # 文本內容
 2 <?xml version="1.0" encoding="GBK"?>
 3     <root>
 4         <head>
 5             <code>1</code>
 6             <message>正確</message>
 7             <value>320202</value>
 8         </head>
 9     </root>
10 
11 
12 # 解析結果
13 {'root': {'head': {'message': u'\u6b63\u786e', 'code': '1', 'value': '320202'}}}

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM