将列表中嵌套的字典按照key值分组

2019-11-01  本文已影响0人  葡萄柚子茶

必须先将字典中的值排序,然后才能用groupby

itemgetteroperator模块提供的itemgetter函数用于获取对象的哪些维的数据,参数为一些索引或键值。

用法示例:

from operator import itemgetter

ll = [1, 2, 3]
dd = {'name': 'mxt', 'age': 18, 'gender': 'female'}

func1 = itemgetter(1)  # 定义函数,获取对象第1个域的值
res1 = func1(ll)  # 2 <class 'int'>

func2 = itemgetter(0, 2)  # 定义函数,获取对象第0个域和第2个的值
res2 = func2(ll)  # (1, 3) <class 'tuple'>

func3 = itemgetter('name')
res3 = func3(dd)  # mxt <class 'str'>

func4 = itemgetter('name', 'gender')
res4 = func4(dd)  # ('mxt', 'female') <class 'tuple'>

注意:operator.itemgetter函数获取的不是值,而是定义了一个函数,通过该函数作用到对象上才能获取值。

from itertools import groupby
from operator import itemgetter
    # result的值
    #[{'user_name': '阿里云', 'operation_type': 'add', 'price': Decimal('1111.00'), 'date_created': datetime.datetime(2019, 10, 30, 15, 26, 52)},
    # {'user_name': '腾讯', 'operation_type': 'add', 'price': Decimal('2222.00'), 'date_created': datetime.datetime(2019, 10, 31, 13, 45, 26)},
    # {'user_name': '阿里云', 'operation_type': 'renew', 'price': Decimal('1234.00'), 'date_created': datetime.datetime(2019, 10, 16, 13, 58, 50)}]

    data = sorted(results, key=lambda x: x['user_name'])

    for vendor_name, items in groupby(data, key=itemgetter('user_name')):
        print(vendor_name, list(items))

结果打印如下:

腾讯 [{'user_name': '腾讯', 'operation_type': 'add', 'price': Decimal('2222.00'), 'date_created': datetime.datetime(2019, 10, 31, 13, 45, 26)}]
阿里云 [{'user_name': '阿里云', 'operation_type': 'add', 'price': Decimal('1111.00'), 'date_created': datetime.datetime(2019, 10, 30, 15, 26, 52)}, {'user_name': '阿里云', 'operation_type': 'renew', 'price': Decimal('1234.00'), 'date_created': datetime.datetime(2019, 10, 16, 13, 58, 50)}]
上一篇下一篇

猜你喜欢

热点阅读