在Python中,我使用module将xml
文件解析为字典。我的代码的核心很简单:
configdict = ConvertXmlToDict('tasks.xml')
for task in configdict['osmo_tasks']['tasks_entries']['entry']:
print task['id'], task['due_date'], task['summary']
上面的代码会将xml
文件解析为字典,然后遍历tasks
并打印出来。显然,它将按照它们从xml
文件中读取的顺序打印它们:
1 736366 summary
2 735444 another summary
5 735796 blah
如何打印根据task['due_date']
排序的行?
这是一个示例xml
文件:
<?xml version="1.0" encoding="utf-8"?>
<osmo_tasks version="000212">
<category_entries/>
<tasks_entries>
<entry>
<id>1</id>
<status>1</status>
<due_date>736366</due_date>
<due_time>53100</due_time>
<summary>summary</summary>
</entry>
<entry>
<id>2</id>
<status>1</status>
<due_date>735444</due_date>
<due_time>55800</due_time>
<summary>another summary</summary>
</entry>
<entry>
<id>5</id>
<status>0</status>
<due_date>735796</due_date>
<due_time>55800</due_time>
<summary>blah</summary>
</entry>
</tasks_entries>
</osmo_tasks>
答案 0 :(得分:5)
尝试使用sorted
内置函数:https://docs.python.org/2/library/functions.html#sorted
sorted
可以使用任何可迭代的键和用于排序的键。这是一个类似于你的例子:
<强> sorted_test.py 强>
configdict = {
'tasks': {
'entries': [
{ 'id': 1, 'date': 736366 },
{ 'id': 2, 'date': 735444 },
{ 'id': 3, 'date': 735796 }
]
}
}
tasks = sorted([ t for t in configdict['tasks']['entries'] ], key=lambda task: task['date'])
print repr(tasks)
结果:
[{'date': 735444, 'id': 2}, {'date': 735796, 'id': 3}, {'date': 736366, 'id': 1}]
答案 1 :(得分:2)