Python中map,filter,reduce,zip的应用

本文介绍了几种使用Python进行高效编程的方法,包括如何通过列表推导式和内置函数简化代码,利用map()和reduce()函数处理复杂的数据结构,以及如何有效地从列表中筛选重复元素。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

事例1:

l=[('main', 'router_115.236.xx.xx', [{'abc': 1}, {'dfg': 1}]),
    ('main', 'router_183.61.xx.xx', [{'abc': 0}, {'dfg': 1}]),
    ('main', 'router_52.11.xx.xx', [{'abc': 0}, {'dfg': 1}]),
    ('main', 'router_183.17.xx.xx', [{'abc': 1}, {'dfg': 1}])
    ]

检查参数l列表中所有item的第二项([{'abc': 1}, {'dfg': 1}])是否相等
for的做法

a=l[0][2]
flag=1
for i in l:
    if a==i[2]:
        continue
    else:
        flag=0
        break

 

高级的做法:

a=map(lambda x:x[2],l)
r=reduce(lambda x,y:x if x==y else False,a)

 

事例2:

a=[{'a':1},{'b':11},{'c':12},{'d':11}]
b=[{'e':14},{'f':17},{'g':18},{'h':41}]

把所以数据合并成一个字典
一般的做法:

a=a+b
c={}
for i in a:
    c.update(i)
print c

高级的做法

def _func(x,y):
    x.update(y)
    return x
c=reduce(_func,a)

 

事例3:

取出一个列表中重复的元素

a = [1,2,3,4,4,5,5,6,9]
b=filter(lambda x:True if a.count(x)>1 else False,a)
c=list(set(b))

输出结果为  [4,5]

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值