python序列,python:从列表(序列)中获取项目数,具有一定条件

Assuming that I have a list with huge number of items.

l = [ 1, 4, 6, 30, 2, ... ]

I want to get the number of items from that list, where an item should satisfy certain condition. My first thought was:

count = len([i for i in l if my_condition(l)])

But if the my_condition() filtered list has also great number of items, I think that

creating new list for filtered result is just waste of memory. For efficiency, IMHO, above call can't be better than:

count = 0

for i in l:

if my_condition(l):

count += 1

Is there any functional-style way to achieve to get the # of items that satisfy certain condition without generating temporary list?

Thanks in advance.

解决方案>>> l = [1, 3, 7, 2, 6, 8, 10]

>>> sum(1 for i in l if i % 4 == 3)

2

or even

>>> sum(i % 4 == 3 for i in l)

2

which uses the fact that int(True) == 1.

Alternatively, you could use itertools.imap (python 2) or simply map (python 3):

>>> def my_condition(x):

... return x % 4 == 3

...

>>> sum(map(my_condition, l))

2

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值