append()
列表方法和列表方法有什么区别extend()
?
20 回答
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']
列表方法追加和扩展有什么区别?
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
。它们在语义上类似于扩展。
my_list + another_list
在内存中创建第三个列表,因此您可以返回它的结果,但它要求第二个可迭代对象是一个列表。
my_list += another_list
就地修改列表(它是就地运算符,列表是可变对象,正如我们所见),因此它不会创建新列表。它也像extend一样工作,因为第二个iterable可以是任何类型的iterable。
不要混淆 -my_list = my_list + another_list
不等同于+=
- 它为您提供分配给 my_list 的全新列表。
时间复杂度
Extend 具有时间复杂度 O(k)。
迭代多个调用append
增加了复杂性,使其与extend 等效,并且由于extend 的迭代是在C 中实现的,因此如果您打算将可迭代的连续项附加到列表中,它总是会更快。
关于“摊销” - 来自列表对象实现源:
/* This over-allocates proportional to the list size, making room
* for additional growth. The over-allocation is mild, but is
* enough to give linear-time amortized behavior over a long
* sequence of appends() in the presence of a poorly-performing
* system realloc().
这意味着我们预先获得了大于需要的内存重新分配的好处,但我们可能会在下一次边际重新分配时付出更大的代价。所有追加的总时间在 O(n) 处是线性的,并且每个追加分配的时间变为 O(1)。
表现
您可能想知道什么更高效,因为 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
解决对时间的评论
一位评论者说:
完美的答案,我只是错过了比较只添加一个元素的时间
做语义上正确的事情。如果要将所有元素附加到可迭代对象中,请使用extend
. 如果您只是添加一个元素,请使用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 中,做语义正确的事情就是用正确的方式做事™。
可以想象,您可能会在两个可比较的操作上测试时序并得到模棱两可或相反的结果。只专注于做语义上正确的事情。
结论
我们看到它在语义上更清晰,并且当您打算将迭代中的每个元素附加到列表时extend
,它可以运行得更快。append
如果您只有一个元素(不在迭代中)要添加到列表中,请使用append
.
append
附加一个元素。extend
附加元素列表。
请注意,如果您传递一个列表来追加,它仍然会添加一个元素:
>>> a = [1, 2, 3]
>>> a.append([4, 5, 6])
>>> a
[1, 2, 3, [4, 5, 6]]
追加与扩展
使用 append,您可以附加一个将扩展列表的元素:
>>> a = [1,2]
>>> a.append(3)
>>> a
[1,2,3]
如果你想扩展多个元素,你应该使用extend,因为你只能附加一个元素或一个元素列表:
>>> a.append([4,5])
>>> a
>>> [1,2,3,[4,5]]
这样你就得到一个嵌套列表
而不是使用extend,您可以像这样扩展单个元素
>>> a = [1,2]
>>> a.extend([3])
>>> a
[1,2,3]
或者,与追加不同,一次扩展更多元素而不将列表嵌套到原始列表中(这就是名称扩展的原因)
>>> a.extend([4,5,6])
>>> a
[1,2,3,4,5,6]
使用两种方法添加一个元素
append 和 extend 都可以将一个元素添加到列表的末尾,尽管 append 更简单。
追加 1 个元素
>>> x = [1,2]
>>> x.append(3)
>>> x
[1,2,3]
扩展一个元素
>>> x = [1,2]
>>> x.extend([3])
>>> x
[1,2,3]
添加更多元素...具有不同的结果
如果您对多个元素使用 append,则必须将元素列表作为参数传递,您将获得一个 NESTED 列表!
>>> x = [1,2]
>>> x.append([3,4])
>>> x
[1,2,[3,4]]
相反,使用extend,您将一个列表作为参数传递,但您将获得一个包含未嵌套在旧元素中的新元素的列表。
>>> z = [1,2]
>>> z.extend([3,4])
>>> z
[1,2,3,4]
因此,对于更多元素,您将使用 extend 来获取包含更多项目的列表。但是,追加列表不会向列表中添加更多元素,而是添加一个嵌套列表的元素,您可以在代码输出中清楚地看到。
以下两个片段在语义上是等效的:
for item in iterator:
a_list.append(item)
和
a_list.extend(iterator)
后者可能会更快,因为循环是用 C 实现的。
该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']
您可以使用“+”返回扩展,而不是就地扩展。
l1=range(10)
l1+[11]
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 11]
l2=range(10,1,-1)
l1+l2
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 9, 8, 7, 6, 5, 4, 3, 2]
+=
就地行为类似,但与append
&略有不同extend
。+=
fromappend
和from的最大区别之一extend
是在函数作用域中使用时,请参阅此博客文章。
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]
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]
这等效于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]]
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]
已经暗示但未解释的一个有趣的点是extend 比append 快。对于任何内部有 append 的循环,都应该考虑用 list.extend(processed_elements) 替换。
请记住,追加新元素可能会导致整个列表重新分配到内存中更好的位置。如果因为我们一次添加 1 个元素而多次这样做,则整体性能会受到影响。从这个意义上说,list.extend 类似于 "".join(stringlist)。
追加一次添加整个数据。整个数据将被添加到新创建的索引中。另一方面,extend
顾名思义,扩展了当前数组。
例如
list1 = [123, 456, 678]
list2 = [111, 222]
append
我们得到:
result = [123, 456, 678, [111, 222]]
在extend
我们得到:
result = [123, 456, 678, 111, 222]
英文词典将单词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)
我希望我可以对这个问题做一个有用的补充。如果您的列表存储了特定类型的对象,例如Info
,这是一种extend
方法不适合的情况:在for
循环中并且Info
每次生成一个对象并将extend
其存储到您的列表中,它将失败。例外情况如下:
TypeError:“信息”对象不可迭代
但是如果你使用该append
方法,结果是可以的。因为每次使用该extend
方法时,总会把它当作一个列表或任何其他集合类型,对其进行迭代,并将其放在上一个列表之后。很明显,一个特定的对象不能被迭代。
直观地区分它们
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'},
}
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]
append
仅通过一项“扩展”列表(就地),即传递的单个对象(作为参数)。
extend
通过传递的对象(作为参数)包含的尽可能多的项目“扩展”列表(就地) 。
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,
追加和扩展是python中的可扩展机制之一。
追加:将一个元素添加到列表的末尾。
my_list = [1,2,3,4]
要将新元素添加到列表中,我们可以通过以下方式使用 append 方法。
my_list.append(5)
添加新元素的默认位置始终位于 (length+1) 位置。
插入:插入方法用于克服附加的限制。使用插入,我们可以明确定义我们希望插入新元素的确切位置。
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]]
如果我们尝试访问 pos 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]