I'm having a mental block, is there a usual python 1-liner for terminating a list comprehension or genex based on some condition? Example usage:
def primes():
# yields forever e.g. 2, 3, 5, 7, 11, 13 ...
[p for p in primes() if p < 10]
# will never terminate, and will go onto infinite loop consuming primes()
[p for p in primes() while p < 10]
# should return [2, 3, 5, 7], and consumed 5 items from my generator
I know about itertools
consume, islice
, but those guys require you to know how many items you want to consume in advance.