2

给定一个数据结构:

   [
    {'id':0, 'items': 
      [
       {'id': 0,  name: "Tom1", age: 10}, 
       {'id': 0, name: "Mark1", age: 15}, 
       {'id': 0, name: "Pam1", age: 17}
      ]
    },
    {'id':1, 'items': 
      [
       {'id': 1,  name: "Tom12", age: 8}, 
       {'id': 1, name: "Mark12", age: 3}, 
       {'id': 1, name: "Pam12", age: 2}
      ]
    },

    {'id':2, 'items': 
      [
       {'id': 2,  name: "Tom13", age: 55}, 
       {'id': 2, name: "Mark13", age: 66}, 
       {'id': 2, name: "Pam13", age: 77}
      ]
    },
  ]

我想在每个字典中找到年龄具有最大值的项目并选择它。我该如何做到这一点?

4

2 回答 2

7

试试这个:

for dVals in yourData:
    print max(dVals['items'], key=lambda x:x['age'])

或单线:

print [max(dVals['items'], key=lambda x: x['age']) for dVals in yourData]

{'id': 0, 'age': 17, 'name': 'Pam1'}
{'id': 1, 'age': 8, 'name': 'Tom12'}
{'id': 2, 'age': 77, 'name': 'Pam13'}
于 2012-11-07T02:35:59.597 回答
0
def find_largest_age(entry):
  return max(entry['items'], key=lambda d: d['age'])

map(find_largest_age, data_structure)

map将函数应用于您的顶级列表中的每个条目。

max将调用列表中key每个成员提供的函数,'items'并返回该函数为其提供最大值的函数。

请注意,您可以将其设为单线:

map(lambda e: max(e['items'], key=lambda d: d['age']), data_structure)

但这更难读。

于 2012-11-07T02:35:47.150 回答