列表方法append()和extend()之间有什么区别?
当前回答
以下两个片段在语义上是等价的:
for item in iterator:
a_list.append(item)
and
a_list.extend(iterator)
后者可能更快,因为循环是在C中实现的。
其他回答
Append一次添加整个数据。整个数据将添加到新创建的索引中。另一方面,extend,顾名思义,扩展当前数组。
例如
list1 = [123, 456, 678]
list2 = [111, 222]
使用append,我们得到:
result = [123, 456, 678, [111, 222]]
在扩展期间,我们得到:
result = [123, 456, 678, 111, 222]
extend()可以与迭代器参数一起使用。这里有一个例子。您希望通过以下方式从列表列表中列出一个列表:
From
list2d = [[1,2,3],[4,5,6], [7], [8,9]]
你想要的
>>>
[1, 2, 3, 4, 5, 6, 7, 8, 9]
您可以使用itertools.chain.from_iterable()来执行此操作。此方法的输出是迭代器。它的实现相当于
def from_iterable(iterables):
# chain.from_iterable(['ABC', 'DEF']) --> A B C D E F
for it in iterables:
for element in it:
yield element
回到我们的例子,我们可以
import itertools
list2d = [[1,2,3],[4,5,6], [7], [8,9]]
merged = list(itertools.chain.from_iterable(list2d))
拿到通缉名单。
以下是如何将extend()等效地用于迭代器参数:
merged = []
merged.extend(itertools.chain.from_iterable(list2d))
print(merged)
>>>
[1, 2, 3, 4, 5, 6, 7, 8, 9]
append在列表末尾附加指定的对象:
>>> x = [1, 2, 3]
>>> x.append([4, 5])
>>> print(x)
[1, 2, 3, [4, 5]]
extend通过从指定的iterable中附加元素来扩展列表:
>>> x = [1, 2, 3]
>>> x.extend([4, 5])
>>> print(x)
[1, 2, 3, 4, 5]
append(object)通过将对象添加到列表来更新列表。
x = [20]
# List passed to the append(object) method is treated as a single object.
x.append([21, 22, 23])
# Hence the resultant list length will be 2
print(x)
--> [20, [21, 22, 23]]
extend(list)本质上连接两个列表。
x = [20]
# The parameter passed to extend(list) method is treated as a list.
# Eventually it is two lists being concatenated.
x.extend([21, 22, 23])
# Here the resultant list's length is 4
print(x)
--> [20, 21, 22, 23]
有一个有趣的点已经被暗示,但没有解释,那就是扩展比追加更快。对于任何内部有append的循环,都应该考虑用list.exextend(processed_elements)替换。
记住,附加新元素可能会导致整个列表重新分配到内存中更好的位置。如果因为一次添加一个元素而多次执行此操作,则会影响整体性能。在这个意义上,list.extend类似于“”.jjoin(stringlist)。