tup = tuple([(element.foo, element.bar) for element in alist])
注:attrgetter并不快(alist这里有一百万个项目):
In [37]: %timeit tuple([(element.foo, element.bar) for element in alist])
1 loops, best of 3: 165 ms per loop
In [38]: %timeit tuple((element.foo, element.bar) for element in alist)
10 loops, best of 3: 155 ms per loop
In [39]: %timeit tuple(map(operator.attrgetter('foo','bar'), alist))
1 loops, best of 3: 283 ms per loop
In [40]: getter = operator.attrgetter('foo','bar')
In [41]: %timeit tuple(map(getter, alist))
1 loops, best of 3: 284 ms per loop
In [46]: %timeit tuple(imap(getter, alist))
1 loops, best of 3: 264 ms per loop
从技术上讲,它是一个generator expression。这就像一个列表理解,但它的评估很慢,不需要为中间列表分配内存。
为了完整起见,列表理解如下:
注:
attrgetter
并不快(alist
这里有一百万个项目):相关问题 更多 >
编程相关推荐