Как я могу использовать понимание списка для построения кортежа из 2-х кортежей из списка. Это было бы эквивалентно
tup = ()
for element in alist:
tup = tup + ((element.foo, element.bar),)
Ответ 1
tup = tuple((element.foo, element.bar) for element in alist)
Технически это выражение generator. Это похоже на понимание списка, но оно оценивается лениво и не нужно выделять память для промежуточного списка.
Для полноты, понимание списка будет выглядеть так:
tup = tuple([(element.foo, element.bar) for element in alist])
PS: 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