在Python中排序对象列表

时间:2014-07-31 22:28:06

标签: python sorting python-2.7

在Python中,我使用modulexml文件解析为字典。我的代码的核心很简单:

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>

2 个答案:

答案 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)

sorted与自定义键功能key一起用于排序

Reference

类似的东西:

sorted(configdict,key=lambda x: x['due_date'])