このコードを考えると:
class XmlObj(dict):
def __init__(self,xml,*args,**kwargs):
super(dict,self).__init__(*args,**kwargs)
if xml.firstChild.nodeName == '#text':
self.__setattr__( 'text', xml.firstChild.nodeValue )
return
else:
for node in xml.childNodes:
if self.has_key( node.nodeName ):
item = self.__getitem__(node.nodeName)
if type( item ) is not type( [] ):
item = [item]
item.append( XmlObj( node ))
self.__setitem__(node.nodeName, item )
else:
self.__setitem__(node.nodeName, XmlObj(node) )
def __str__(self):
if hasattr(self,'text'):
return self.__getattribute__('text')
else:
return "%s"%super(dict,self).__str__()
text = """<?xml version="1.0"?><response><success>true</success><message>Metric List</message><page>1</page><rpp>50</rpp><total>9</total><pages>1</pages></response>"""
obj = XmlObj( parseString( text ).documentElement )
print obj
print obj['rpp']
>>> {u'rpp': {}, u'success': {}, u'pages': {}, u'message': {}, u'total': {}, u'page': {}}
>>> 50
入手したい:
>>> {u'rpp': '50', u'success': True, u'pages': 4, u'message': 'Some message', u'total': 90, u'page': 1}
Pythonが__repr__
オブジェクトの呼び出しをどのように処理して、内部のobjパラメーターを取得しtext
、空のdictではなく属性を表示するのか疑問に思います。