1. 使用字典的viewkeys( ) 方法,得到一个字典keys的集合
2. 使用map函数,得到所有字典的keys的集合
3. 使用reduce函数,获取所有字典的keys的集合的交集
a = { '马云':2387, '马化腾':2263, '许家印':2125, '王健林':1566, '何享健':1345 }
b = { '杰夫·贝佐斯':7750,'马云':2387, '沃伦·巴菲特':6450,'马化腾':2263, '比尔·盖茨':5700 }
c = { '杰克':4533, '沃伦·巴菲特':1240, '马云':2347, '比尔·盖茨':5200 }
方法一
a.viewkeys()
输出 dict_keys(['马云', '马化腾','许家印','王健林','何享健'])
利用集合的交集方式
a.viewkeys()&b.viewkeys( ) & c.viewkeys( )
输出 { '马云'}
方法二
map(dict.viewkeys,[ a, b, c] )
输出 [dict_keys(['马云','马化腾','许家印','王健林', '何享健']),
dict_keys([ '杰夫·贝佐斯' ,..]),
dict_keys([ '杰克' ,..]),
reduce(lambda a, b: a & b, map(dict.viewkeys, [a, b, c]))
输出 {'马云'}
reduce() 函数会对参数序列中元素进行累积
函数将一个数据集合(链表,元组等)中的所有数据进行下列操作:用传给 reduce 中的函数 function(有两个参数)先对集合中的第 1、2 个元素进行操作,得到的结果再与第三个数据用 function 函数运算,最后得到一个结果。
reduce(lambda x, y: x+y, [1,2,3,4,5]) # 使用 lambda 匿名函数
15
第一个参数 function 以参数序列中的每一个元素调用 function 函数,返回包含每次 function 函数返回值的新列表
map(lambda x: x ** 2, [1, 2, 3, 4, 5]) # 使用 lambda 匿名函数
[1, 4, 9, 16, 25]
提供了两个列表,对相同位置的列表数据进行相加
map(lambda x, y: x + y, [1, 3, 5, 7, 9], [2, 4, 6, 8, 10])
[3, 7, 11, 15, 19]
列表中字典聚合
a = [
{"user":'a', "age":2},
{"user":"a", "age":1}
]
temp ={}
for i in a:
temp.setdefault(i.get("user"), []).append(i.get("age"))
print(temp)
{‘a’: [2, 1]}
class Cat(dict):
def __getattr__(self, item):
return self[item]
r = {'z': 1, 'x': 2}
cat = Cat(r)
print(cat.z)