我有以下结构的python字典:
d={ 'cfdi:Emisor': {'rfc': u'ALF040329CX6', 'nombre': u'ALFATECH, S.A. DE C.V.',
'cfdi:RegimenFiscal': {'Regimen': u'Personas morales del r\xe9gimen general'},
'cfdi:ExpedidoEn': {'calle': u'ING. INDUSTRIALES', 'localidad': u'MORELIA', 'pais': u'M\xe9xico', 'noInterior': 'N/A', 'colonia': u'BUENAVISTA 1A ETAPA', 'noExterior': u'215', 'codigoPostal': u'58228', 'estado': u'Michoac\xe1n', 'municipio': u'MORELIA'},
'cfdi:DomicilioFiscal': {'calle': u'ING. INDUSTRIALES', 'localidad': u'MORELIA', 'pais': u'M\xe9xico', 'noInterior': 'N/A', 'colonia': u'BUENAVISTA 1A ETAPA', 'noExterior': u'215', 'codigoPostal': u'58228', 'estado': u'Michoac\xe1n', 'municipio': u'MORELIA'},
}}
这个结构由字典中的字典组成。我需要将其转换为XML,然后我得到了以下代码来实现:
^{pr2}$此函数在上一个字典中工作正常,并返回以下内容:
<cfdi:Emisor nombre="ALFATECH, S.A. DE C.V." rfc="ALF040329CX6">
<cfdi:RegimenFiscal Regimen="Personas morales del régimen general"/>
<cfdi:ExpedidoEn calle="ING. INDUSTRIALES" codigoPostal="58228" colonia="BUENAVISTA 1A ETAPA" estado="Michoacán" localidad="MORELIA" municipio="MORELIA" noExterior="215" noInterior="N/A" pais="México"/>
<cfdi:DomicilioFiscal calle="ING. INDUSTRIALES" codigoPostal="58228" colonia="BUENAVISTA 1A ETAPA" estado="Michoacán" localidad="MORELIA" municipio="MORELIA" noExterior="215" noInterior="N/A" pais="México"/>
</cfdi:Emisor>
这就是我一直在等待的,但现在我需要对这个结构基本相同但包含不同元素的字典执行相同的操作:
d3={ 'catalogocuentas:Catalogo': {'rfc': u'ALF040329CX6', 'xmlns:catalogocuentas':'"http://www.sat.gob.mx/catalogocuentas"', 'xmlns:xsi':'"http://www.w3.org/2001/XMLSchema-instance"', 'xsi:schemaLocation':'"http://www.sat.gob.mx//catalogocuentas"', 'Ano':'2014', 'Mes':'02', 'TotalCtas':'219','version':'1.0',
'catalogocuentas:Ctas': {'Natur': u'D', 'nivel':'2', 'SubCtaDe':'1110-000-000', 'Desc':'CAJA CHICA', 'NumCta':'1110-001-000', 'CodAgrup':'1.1'},
'catalogocuentas:Ctas': {'Natur': u'D', 'nivel':'3', 'SubCtaDe':'1120-001-000', 'Desc':'Banamex 741107-1', 'NumCta':'1120-001-001', 'CodAgrup':'2.1'},
'catalogocuentas:Ctas': {'Natur': u'D', 'nivel':'3', 'SubCtaDe':'1120-001-000', 'Desc':'Bancomer 12911256971', 'NumCta':'1120-001-002', 'CodAgrup':'2.1'}
}}
你们可以看到,主要的区别是这个字典对于内部元素(dictionaries)有相同的标记,我得到了以下结果:
<?xml version="1.0" encoding="utf-8"?>
<catalogocuentas:Catalogo Ano="2014" Mes="02" TotalCtas="219" rfc="ALF040329CX6" version="1.0" xmlns:catalogocuentas=""http://www.sat.gob.mx/catalogocuentas"" xmlns:xsi=""http://www.w3.org/2001/XMLSchema-instance"" xsi:schemaLocation=""http://www.sat.gob.mx//catalogocuentas"">
<catalogocuentas:Ctas CodAgrup="2.1" Desc="Bancomer 12911256971" Natur="D" NumCta="1120-001-002" SubCtaDe="1120-001-000" nivel="3"/>
</catalogocuentas:Catalogo>
如您所见,我只从d3得到最后一个元素(字典),而不是所有元素。在
由此我可以得出结论,问题可能是在这个字典中,我的所有元素都有相同的标记。在
这是真正的问题吗?在
如有任何建议,我们将不胜感激!!!在
提前谢谢。在
已经存在用于此one of which I created的库。使用
xmler
包,您可以轻松地将字典转换为以下xml:为了获得这个XML结构并使其正确打印,您必须稍微修改一下字典,因为您当前没有为
^{pr2}$cfdi
定义XML名称空间。我使用了以下词典:然后跑了
注意字典中的
@attrs
键。它向元素添加属性。您也可以在这里使用@ns
键来设置名称空间,而不是使用冒号分隔的字符串。在你的代码格式让我的眼睛很痛。Pythonformatting style guide是你的朋友。尤其是你滥用了最大线长度。在
如果要将python字典格式化为XML,有许多标准选项。看这个previous question for some solutions.
Python字典只允许一个元素基于同一个键,重复的条目覆盖前面的条目。在
相关问题 更多 >
编程相关推荐