列表推导以相同的方式嵌套循环.因此,最外层的循环位于最内层循环之前.
>>> x = 'green apple' >>> [c for word in x.split() for c in word] ['g', 'r', 'e', 'e', 'n', 'a', 'p', 'p', 'l', 'e']
我通常不使用嵌套列表推导,因为我发现我并不总是记住顺序,但我知道有些人确实使用它们,因此能够记住它们如何嵌套是有用的.
在这种情况下,我通常更喜欢使用itertools.chain
:
import itertools print list(itertools.chain.from_iterable(x.split()))
x = 'green apple' print [i for i in x if i !=" "]
你可以直接这样做.
输出:['g', 'r', 'e', 'e', 'n', 'a', 'p', 'p', 'l', 'e']
要么
import re x = 'green apple' print re.findall("\S",x)