編集
辞書はここでは犯罪者です、この質問にマークされた答えは機能します、しかし辞書はそれが望むことをします。この場合、辞書の並べ替えが答えですが、属性を使用してノードを並べ替える方法がわかりました。
終わり
Pythonの質問をすることができてとてもうれしいです。これが私が持っているものです:
def parse_fixed_data(self, format):
return_message = {}
nodes = format.getElementsByTagName('data')
for node in nodes:
return_message[node.attributes['name'].value] = self.raw_message[int(node.attributes['from'].value):int(node.attributes['to'].value)]
return return_message
これはほとんど美しく機能します。'format'変数は、すでに解析されたノードであり、'data'ノードの束が含まれています。xmlは次のとおりです。
<pmbmsg id='pmb_header'>
<version maj='01' min='00' rev='0000' type='FIXED' delimeter=''>
<data seq='1' from='0' to='3' name='message_type'/>
<data seq='2' from='3' to='13' name='version'/>
<data seq='3' from='13' to='33' name='from_system'/>
<data seq='4' from='33' to='53' name='to_system'/>
<data seq='5' from='53' to='73' name='family'/>
<data seq='6' from='73' to='83' name='priority'/>
<data seq='7' from='83' to='103' name='msg_format_id'/>
<data seq='8' from='103' to='135' name='msg_unique_id'/>
<data seq='9' from='135' to='161' name='created'/>
<data seq='10' from='161' to='163' name='hop_count'/>
<data seq='11' from='163' to='173' name='original_msg_format_id'/>
<data seq='12' from='173' to='205' name='original_unique_id'/>
<data seq='13' from='205' to='245' name='padding'/>
<data seq='14' from='245' to='4086' name='message_data'/>
</version>
</pmbmsg>
これはすべてうまく機能しますが、辞書要素を次の順序で取得します。
u'to_system'
u'padding'
u'original_msg_format_id'
u'original_unique_id'
u'family'
u'created'
u'msg_format_id'
u'hop_count'
u'msg_unique_id'
u'priority'
u'version'
u'from_system'
u'message_type'
u'message_data'
(値が削除されました)
xmlに表示される順序で戻ってきてほしいのですが、seq属性がこれに役立つ可能性があります。Pythonコードのこの行の後:
nodes = format.getElementsByTagName('data')
...これをソートするノードで実行できる関数はありますか?または、ノードを取得するときに、それらを並べ替えることを通知する何かを述べることができますか?xmlが書かれた順序で自然に取得できると思いますか?
これを自動的に魔法のように実行する機能がない場合は、ハッキングを処理できます。