列表方法
append()
和extend()
有什么区别?#1 楼
append
:在末尾附加对象。x = [1, 2, 3]
x.append([4, 5])
print (x)
给您:
[1, 2, 3, [4, 5]]
extend
:通过从列表中附加元素来扩展列表可迭代。x = [1, 2, 3]
x.extend([4, 5])
print (x)
为您提供:
[1, 2, 3, 4, 5]
#2 楼
append
将一个元素添加到列表中,并且extend
将第一个列表与另一个列表(或另一个可迭代的,不一定是列表)连接起来。>>> li = ['a', 'b', 'mpilgrim', 'z', 'example']
>>> li
['a', 'b', 'mpilgrim', 'z', 'example']
>>> li.append("new")
>>> li
['a', 'b', 'mpilgrim', 'z', 'example', 'new']
>>> li.append(["new", 2])
>>> li
['a', 'b', 'mpilgrim', 'z', 'example', 'new', ['new', 2]]
>>> li.insert(2, "new")
>>> li
['a', 'b', 'new', 'mpilgrim', 'z', 'example', 'new', ['new', 2]]
>>> li.extend(["two", "elements"])
>>> li
['a', 'b', 'new', 'mpilgrim', 'z', 'example', 'new', ['new', 2], 'two', 'elements']
#3 楼
list方法的append和extend有什么区别?
append
将其参数作为单个元素添加到列表的末尾。列表本身的长度将增加一。extend
遍历其参数,将每个元素添加到列表中,从而扩展了列表。列表的长度将增加,但是可迭代参数中包含许多元素。append
list.append
方法将一个对象附加到列表的末尾。 > my_list.append(object)
无论对象是什么,无论是数字,字符串,另一个列表还是其他内容,它都作为列表上的单个条目添加到
my_list
的末尾。 >>> my_list
['foo', 'bar']
>>> my_list.append('baz')
>>> my_list
['foo', 'bar', 'baz']
因此请记住,列表是一个对象。如果将另一个列表追加到列表中,则第一个列表将是列表末尾的单个对象(可能不是您想要的):
>>> another_list = [1, 2, 3]
>>> my_list.append(another_list)
>>> my_list
['foo', 'bar', 'baz', [1, 2, 3]]
#^^^^^^^^^--- single item at the end of the list.
extend
方法list.extend
方法通过添加来自可迭代对象的元素来扩展列表:my_list.extend(iterable)
因此,通过扩展,可迭代对象的每个元素都被附加了到列表上。例如:
>>> my_list
['foo', 'bar']
>>> another_list = [1, 2, 3]
>>> my_list.extend(another_list)
>>> my_list
['foo', 'bar', 1, 2, 3]
请记住,字符串是可迭代的,因此,如果用字符串扩展列表,则在迭代时将附加每个字符字符串(可能不是您想要的字符串):
>>> my_list.extend('baz')
>>> my_list
['foo', 'bar', 1, 2, 3, 'b', 'a', 'z']
运算符重载,
__add__
(+
)和__iadd__
(+=
)为
+
定义了+=
和list
运算符。它们在语义上与extend相似。my_list + another_list
在内存中创建第三个列表,因此您可以返回它的结果,但它要求第二个可迭代的对象为列表。 my_list += another_list
就地修改列表(如我们所见,它是就地运算符,并且列表是可变对象),因此不会创建新列表。它也可以像extend一样工作,因为第二个可迭代对象可以是任何类型的可迭代对象。 时间复杂度
附录具有恒定的时间复杂度O(1)。
扩展具有时间复杂度O(k)。
遍历对
my_list = my_list + another_list
的多次调用增加了复杂性,使其等同于extend的复杂性,并且因为extend的迭代是在C中实现的,所以如果您打算从性能
您可能会想知道哪个性能更好,因为append可用于实现与extend相同的结果。以下功能可实现相同的功能:
def append(alist, iterable):
for item in iterable:
alist.append(item)
def extend(alist, iterable):
alist.extend(iterable)
,让我们为它们计时:
import timeit
>>> min(timeit.repeat(lambda: append([], "abcdefghijklmnopqrstuvwxyz")))
2.867846965789795
>>> min(timeit.repeat(lambda: extend([], "abcdefghijklmnopqrstuvwxyz")))
0.8060121536254883
发表评论关于时间安排
评论者说:
完美的答案,我只是错过了只添加一个元素进行比较的时间安排
做语义上正确的事情。如果要以可迭代方式附加所有元素,请使用
+=
。如果您仅添加一个元素,请使用append
。好,让我们创建一个实验来看看如何及时实现:
def append_one(a_list, element):
a_list.append(element)
def extend_one(a_list, element):
"""creating a new list is semantically the most direct
way to create an iterable to give to extend"""
a_list.extend([element])
import timeit
而且我们发现,竭尽全力创建仅可使用扩展的可迭代方法是(少量)浪费时间:
>>> min(timeit.repeat(lambda: append_one([], 0)))
0.2082819009956438
>>> min(timeit.repeat(lambda: extend_one([], 0)))
0.2397019260097295
我们从中学到了当仅添加一个元素时,使用
extend
并没有任何好处。这些时间也不是那么重要。我只是向他们表明,在Python中做语义正确的事情就是按照Right Way™进行事情。
可以想象,您可以在两个可比较的操作上测试时序,并得到模棱两可或相反的结果。只需专注于完成语义上正确的事情。
结论
我们看到
append
的语义更清晰,并且当您打算附加每个时,它的运行速度比extend
快得多。可迭代到列表中的元素。 如果只有一个元素(不可迭代)添加到列表中,请使用
extend
。评论
@Aaron Hall关于计时算法的一个小评论。 “ extend_one”可能返回“稍微错误”的时间,因为还涉及列表的创建。如果您想更严格一些的话,最好将项目创建为变量(ex1 = 0和ex2 = [0])并传递这些变量。
–ilias iliadis
18年3月31日在18:06
确实是完美的答案。 l1 + = l2 vs l1.extend(l2)的性能如何?
–让-弗朗索瓦·T。
18-4-23在3:54
@ Jean-FrancoisT .: l1 + = l2和l1.extend(l2)最终执行相同的代码(listobject.c中的list_extend函数)。唯一的区别是:1. + =重新分配l1(用于列表本身,但重新分配支持不属于同一对象的不可变类型),如果l1实际上是不可变对象的属性,则使其成为非法;例如,t =([],),t [0] + = lst将失败,而t [0] .extend(lst)将起作用。 2. l1 + = l2使用专用字节码,而l1.extend(l2)使用广义方法分派;这使得+ =比扩展快。
–ShadowRanger
18年8月17日在19:10
+ =必须重新分配l1的事实确实意味着,在某些情况下,扩展的较慢分配是通过不分配回左侧来部分或完全弥补的。例如,如果列表是对象的属性,则self.l1 + = l2和self.l1.extend(l2)在我的Python 3.6安装中具有相同的性能,这仅仅是因为实际操作更像self.l1 = self。 l1 .__ iadd __(l2),这意味着它必须执行self.l1.extend(l2)不需要的中等昂贵的STORE_ATTR。
–ShadowRanger
18年8月17日在19:20
本地测试中的简单比较:对于本地变量(因此+ =仅使用STORE_FAST,这非常便宜),其中添加的值是其中包含一项的现有列表,并且该操作重复了1000次,+ =平均花费约33 ns,而延长花费78 ns,相差45 ns。如果l1是全局变量(需要更昂贵的STORE_GLOBAL),则差异缩小到17 ns。如果l1实际上是local.l1(需要更昂贵的STORE_ATTR),则+ =和extend(时间大致相同; extended有时会获胜)之间没有有意义的区别。
–ShadowRanger
18年8月17日在19:32
#4 楼
append
附加了一个元素。 extend
追加元素列表。请注意,如果传递要追加的列表,它仍会添加一个元素:
>>> a = [1, 2, 3]
>>> a.append([4, 5, 6])
>>> a
[1, 2, 3, [4, 5, 6]]
#5 楼
附加与扩展使用附加,您可以附加单个元素来扩展列表:
>>> a = [1,2]
>>> a.append(3)
>>> a
[1,2,3]
如果要扩展多个元素,则应使用扩展,因为您只能附加一个元素或一个元素列表:
>>> a.append([4,5])
>>> a
>>> [1,2,3,[4,5]]
,这样您就可以嵌套列表
可以通过扩展而不是用extend来扩展单个元素,例如
>>> a = [1,2]
>>> a.extend([3])
>>> a
[1,2,3]
或者,与append不同的是,在一次而不将列表嵌套到原始列表中(这是名称扩展的原因)
>>> a.extend([4,5,6])
>>> a
[1,2,3,4,5,6]
两种方法都添加一个元素
追加和扩展都可以在列表的末尾添加一个元素,尽管追加操作比较简单。
追加1个元素
>>> x = [1,2]
>>> x.append(3)
>>> x
[1,2,3]
扩展一个元素
>>> x = [1,2]
>>> x.extend([3])
>>> x
[1,2,3]
添加更多元素...得到不同的结果
如果使用appe如果有多个元素,则必须传递一个元素列表作为参数,您将获得一个NESTED列表!
>>> x = [1,2]
>>> x.append([3,4])
>>> x
[1,2,[3,4]]
通过extend,您传递一个list作为参数,但是您将获得一个列表,其中包含一个新元素,而该新元素没有嵌套在旧元素中。
>>> z = [1,2]
>>> z.extend([3,4])
>>> z
[1,2,3,4]
因此,使用更多元素,您将使用扩展以获取包含更多项的列表。
但是,添加列表不会在列表中添加更多元素,而是一个嵌套列表的元素,您可以在代码输出中清楚地看到。
#6 楼
以下两个摘要在语义上是等效的:for item in iterator:
a_list.append(item)
和
a_list.extend(iterator)
循环在C中实现。
评论
在我的机器上,扩展比在循环中快4倍(16us与100us零循环的4us相比)
– Alex L
2012年12月27日上午8:29
extend()可能会预先分配,而append()可能不会。
–疯狂物理学家
15-10-23在13:43
@MadPhysicist:出于完整性的考虑,有时extend()无法明智地预分配,因为某些可迭代对象未实现__len __(),但像您一样,如果不尝试,我会感到惊讶。正如Aaron的答案所指出的那样,部分性能提升还来自纯C语言而不是Python的迭代部分。
–索伦·比约恩斯塔德(Soren Bjornstad)
19年7月28日在3:43
#7 楼
append()
方法将一个项目添加到列表的末尾。x = [1, 2, 3]
x.append([4, 5])
x.append('abc')
print(x)
# gives you
[1, 2, 3, [4, 5], 'abc']
extend()
方法使用一个参数,一个列表,并将该参数的每个项目附加到后面到原始列表。 (列表被实现为类。“创建”列表实际上是在实例化一个类。因此,列表具有对其进行操作的方法。)x = [1, 2, 3]
x.extend([4, 5])
x.extend('abc')
print(x)
# gives you
[1, 2, 3, 4, 5, 'a', 'b', 'c']
从Dive进入Python。
评论
您不能只扩展6,因为它是不可迭代的。您的示例中的第二个输出是错误的。自从您将“ abc”添加为一个元素以来,它就被扩展为具有一个元素['abc']的列表:[1、2、3、4、5,'abc']。为了使示例输出正确,请将abc行更改为:x.extend('abc')。并删除x.extend(6)或将其更改为x.extend([6])。
–类胡萝卜素
2014-09-25 9:28
#8 楼
您可以使用“ +”来返回扩展,而不是就地扩展。+=
与append
和extend
的最大区别之一是在函数范围内使用时,请参见此博客文章。评论
使用“ +”返回扩展是否对时间复杂度有影响?
–富兰克林
2015年7月19日,下午3:59
@franklin,有关详细信息,请参见此答案:stackoverflow.com/a/28119966/2230844
–denfromufa
15年7月21日在14:50
我不知道这如何回答问题
–pppery
18年7月13日在3:20
#9 楼
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]
#10 楼
extend()
可以与迭代器参数一起使用。这是一个例子。您希望通过以下方式从列表列表中列出:来自
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]
评论
该答案与扩展没有相反,因此不回答问题
–pppery
18年7月13日在3:20
#11 楼
这等效于使用append
运算符的extend
和+
:>>> x = [1,2,3]
>>> x
[1, 2, 3]
>>> x = x + [4,5,6] # Extend
>>> x
[1, 2, 3, 4, 5, 6]
>>> x = x + [[7,8]] # Append
>>> x
[1, 2, 3, 4, 5, 6, [7, 8]]
评论
为什么不= +?更简洁
–denfromufa
2015年9月13日在2:18
#12 楼
append():基本上在Python中用于添加一个元素。示例1:
>> a = [1, 2, 3, 4]
>> a.append(5)
>> print(a)
>> a = [1, 2, 3, 4, 5]
示例2:
>> a = [1, 2, 3, 4]
>> a.append([5, 6])
>> print(a)
>> a = [1, 2, 3, 4, [5, 6]]
extend():其中extend()用于合并两个列表或在一个列表中插入多个元素列表。
示例1:
>> a = [1, 2, 3, 4]
>> b = [5, 6, 7, 8]
>> a.extend(b)
>> print(a)
>> a = [1, 2, 3, 4, 5, 6, 7, 8]
示例2:
>> a = [1, 2, 3, 4]
>> a.extend([5, 6])
>> print(a)
>> a = [1, 2, 3, 4, 5, 6]
#13 楼
已经暗示但没有解释的一个有趣的观点是,扩展比附加要快。对于任何在内部具有append的循环,都应考虑将其替换为list.extend(processed_elements)。请记住,添加新元素可能会导致整个列表重新定位到位置更好的位置。记忆。如果由于一次添加1个元素而多次执行此操作,则总体性能会受到影响。从这个意义上说,list.extend类似于“” .join(stringlist)。
#14 楼
Append一次添加全部数据。整个数据将被添加到新创建的索引中。另一方面,顾名思义,extend
扩展了当前数组。 例如
list1 = [123, 456, 678]
list2 = [111, 222]
使用
append
我们得到:result = [123, 456, 678, [111, 222]]
在
extend
上,我们得到:result = [123, 456, 678, 111, 222]
#15 楼
英文词典将append
和extend
定义为:append:在书面文档的末尾添加(某些内容)。扩大:扩大。放大或扩展
有了这些知识,现在让我们理解
1)
append
和extend
之间的区别append
:将所有Python对象原样追加到列表的末尾(即,作为列表中的最后一个元素)。
结果列表可以嵌套并包含异构元素(即列表,字符串,元组,字典,集合等)。
extend
:接受任何可迭代的参数作为参数并使列表
结果列表始终是一维列表(即无嵌套),并且由于应用
list(iterable)
而导致其中可能包含异类元素(例如,字符,整数,浮点数)。2)
append
和extend
之间的相似性两者都正好采用一个参数。
两者都就地修改了列表。
结果均返回
None
。 示例
lis = [1, 2, 3]
# 'extend' is equivalent to this
lis = lis + list(iterable)
# 'append' simply appends its argument as the last element to the list
# as long as the argument is a valid Python object
list.append(object)
#16 楼
我希望我可以对这个问题做出有益的补充。如果您的列表存储了特定类型的对象,例如Info
,则可能是extend
方法不适合的情况:在for
循环中,每次生成一个Info
对象,并使用extend
将其存储到列表中,它将失败。异常如下所示:TypeError:'Info'对象不可迭代
但是如果使用
append
方法,则结果为好。因为每次使用extend
方法,它将始终将其视为列表或任何其他集合类型,对其进行迭代,并将其放置在上一个列表之后。显然,不能迭代特定的对象。#17 楼
直观地区分它们l1 = ['a', 'b', 'c']
l2 = ['d', 'e', 'f']
l1.append(l2)
l1
['a', 'b', 'c', ['d', 'e', 'f']]
就像
l1
在其体内复制一个身体(嵌套)一样。# Reset l1 = ['a', 'b', 'c']
l1.extend(l2)
l1
['a', 'b', 'c', 'd', 'e', 'f']
>这就像是两个分开的人结婚并组建了一个家庭。
此外,我还详尽列出了所有列表的方法供您参考。
list_methods = {'Add': {'extend', 'append', 'insert'},
'Remove': {'pop', 'remove', 'clear'}
'Sort': {'reverse', 'sort'},
'Search': {'count', 'index'},
'Copy': {'copy'},
}
#18 楼
extend(L)
通过添加给定列表L
中的所有项目来扩展列表。>>> a
[1, 2, 3]
a.extend([4]) #is eqivalent of a[len(a):] = [4]
>>> a
[1, 2, 3, 4]
a = [1, 2, 3]
>>> a
[1, 2, 3]
>>> a[len(a):] = [4]
>>> a
[1, 2, 3, 4]
#19 楼
append
仅将一项传递给对象(作为参数)“扩展”列表(在适当位置)。extend
q将“传递”列表项与通过对象的尽可能多的条目扩展(在适当位置) (作为参数)包含。这对于
str
对象可能会有些混乱。如果将字符串作为参数传递:
append
将添加最后一个单个字符串项,但extend
将添加与该字符串的长度一样多的“单个”'str'项。如果您将字符串列表作为参数传递:
append
仍将在末尾添加单个“列表”项,并且extend
将添加与传递列表的长度一样多的“列表”项。def append_o(a_list, element):
a_list.append(element)
print('append:', end = ' ')
for item in a_list:
print(item, end = ',')
print()
def extend_o(a_list, element):
a_list.extend(element)
print('extend:', end = ' ')
for item in a_list:
print(item, end = ',')
print()
append_o(['ab'],'cd')
extend_o(['ab'],'cd')
append_o(['ab'],['cd', 'ef'])
extend_o(['ab'],['cd', 'ef'])
append_o(['ab'],['cd'])
extend_o(['ab'],['cd'])
产品:
append: ab,cd,
extend: ab,c,d,
append: ab,['cd', 'ef'],
extend: ab,cd,ef,
append: ab,['cd'],
extend: ab,cd,
#20 楼
追加和扩展是python中的可扩展性机制之一。追加:将元素添加到列表的末尾。
my_list = [1,2,3,4]
要向列表中添加新元素,可以按以下方式使用append方法。
my_list.append(5)
要添加新元素的默认位置始终位于(length + 1)位置。
插入:使用insert方法克服了append的局限性。使用insert,我们可以显式定义要在其中插入新元素的确切位置。
insert(index,object)的方法描述符。它有两个参数,第一个是我们要插入元素的索引,第二个是元素本身。
Example: my_list = [1,2,3,4]
my_list[4, 'a']
my_list
[1,2,3,4,'a']
扩展:当我们要将两个或多个列表合并为一个列表时,这非常有用。如果不扩展,如果我们要连接两个列表,则生成的对象将包含一个列表列表。
a = [1,2]
b = [3]
a.append(b)
print (a)
[1,2,[3]]
如果尝试访问位置2的元素,则会得到一个列表([3]),而不是元素。要加入两个列表,我们必须使用append。
a = [1,2]
b = [3]
a.extend(b)
print (a)
[1,2,3]
要加入多个列表
a = [1]
b = [2]
c = [3]
a.extend(b+c)
print (a)
[1,2,3]
评论
您为什么要回答已经回答很多次的问题?这个问题已经十岁了...
– Mike-SMT
18年8月3日在13:19
评论
扩展和简单地使用加法运算符之间有什么区别-在上面的示例中,x = x + [4,5]?
–罗汉
17年5月29日在22:10
实际上有很大的不同-x + [4,5]为您分配了一个新列表x-x.extend()改变了原始列表。我在下面详细说明我的答案。
–亚伦·霍尔♦
17年7月17日在17:14
@AaronHall @Rohan,但它与x + = [4,5]相同。
– Astitva Srivastava
18/12/13在14:54
@AstitvaSrivastava实际上,我认为扩展在字节码方面更快
–MilkyWay90
18/12/21在16:22
使用append时的关键字是Object。如果尝试使用extend并传入字典,它将把键而不是整个哈希附加到数组的末尾。
–安东尼
19 Mar 15 '19在14:53