不得不多次迭代列表是不优雅的恕我直言.
我可能会创建一个允许执行以下操作的函数:
twos, threes = countmatching(xrange(1,10), lambda a: a % 2 == 0, lambda a: a % 3 == 0)
一个起点是这样的:
def countmatching(iterable, *predicates): v = [0] * len(predicates) for e in iterable: for i,p in enumerate(predicates): if p(e): v[i] += 1 return tuple(v)
顺便说一句,"itertools食谱"有一个很像你的alt4的配方.
def quantify(seq, pred=None): "Count how many times the predicate is true in the sequence" return sum(imap(pred, seq))
Alt 4!但也许你应该将代码重构为一个函数,该函数接受一个应该包含可分数(两个和三个)的参数.然后你可以有一个更好的功能名称.
def methodName(divNumber, r): return sum(1 for v in r if v % divNumber == 0) print methodName(2, xrange(1, 10)) print methodName(3, xrange(1, 10))