python中append的用法_python中的 list (列表)append()方法 与extend()方法的用法 和 区别...

append()方法使用

首先看官方文档中的描述:

list.extend(L) Extend the list by appending all the items in the given list; equivalent to a[len(a):] = L.

翻译成汉语就是: 通过将所有元素追加到已知list来扩充它,相当于a[len(a):]= L

举个例子,更能明白这句话

>>> la

[1, 2, 3]

>>> lb

['qiwsir', 'python']

>>> la.extend(lb)

>>> la

[1, 2, 3, 'qiwsir', 'python']

>>> lb

['qiwsir', 'python']

如果有两个list,一个是la,另外一个lb,将lb追加到la的后面,也就是把lb中的所有元素加入到la中,

即让la扩容。看代码

>>> la = [1,2,3]

>>> b = "abc"

>>> la.extend(b)

>>> la

[1, 2, 3, 'a', 'b', 'c']

>>> c = 5

>>> la.extend(c)

Traceback (most recent call last):

File "", line 1, in

TypeError: 'int' object is not iterable

原来,如果extend(str)的时候,str被以字符为单位拆开,然后追加到la里面。如果extend的对象是数值型,则报错。

所以,extend的对象是一个list,如果是str,则python会先把它按照字符为单位转化为list再追加到已知list。

>>> la

[1, 2, 3, 'a', 'b', 'c']

>>> lb

['qiwsir', 'python']

>>> la[len(la):]=lb

>>> la

[1, 2, 3, 'a', 'b', 'c', 'qiwsir', 'python']

为什会出现输入la,运行后 [1, 2, 3, 'a', 'b', 'c', 'qiwsir', 'python'] 因为list.extend(L) 等效于 list[len(list):] = L, L是待并入的list。

extend()方法使用

>>> new = [1,2,3]

>>> lst = ['python','qiwsir']

>>> lst.extend(new)

>>> lst

['python', 'qiwsir', 1, 2, 3]

>>> new

[1, 2, 3]

通过extend函数,将[1,2,3]中的每个元素都拿出来,然后塞到lst里面,从而得到了一个跟原来的对象元素不一样的列表,后面的比原来的多了三个元素。

还要关注一下,从上面的演示中可以看出,lst经过extend函数操作之后,变成了一个貌似“新”的列表。这句话好像有点别扭,“貌似新”的,之所以这么说,是因为对“新的”可能有不同的理解。不妨深挖一下。

>>> new = [1,2,3]

>>> id(new)

3072383244L

>>> lst = ['python', 'qiwsir']

>>> id(lst)

3069501420L

用id()能够看到两个列表分别在内存中的“窝”的编号。

>>> lst.extend(new)

>>> lst

['python', 'qiwsir', 1, 2, 3]

>>> id(lst)

3069501420L

注意到没有?虽然lst经过extend()方法之后,比原来扩容了,但是,并没有离开原来的“窝”,也就是在内存中,还是“旧”的,只不过里面的内容增多了。相当于两口之家,经过一番云雨之后,又增加了一个小宝宝,那么这个家是“新”的还是“旧”的呢?角度不同或许说法不一了。

这就是列表的一个重要特征:列表是可以修改的。这种修改,不是复制一个新的,而是在原地进行修改。

其实,append()对列表的操作也是如此,不妨用同样的方式看看。

说明:虽然这里的lst内容和上面的一样,但是,我从新在shell中输入,所以id会变化。也就是内存分配的“窝”的编号变了。

>>> lst = ['python','qiwsir']

>>> id(lst)

3069501388L

>>> lst.append(new)

>>> lst

['python', 'qiwsir', [1, 2, 3]]

>>> id(lst)

3069501388L

显然,append()也是原地修改列表。

如果,对于extend(),提供的不是iterable类型对象,会如何呢?

>>> lst.extend("itdiffer")

>>> lst

['python', 'qiwsir', 'i', 't', 'd', 'i', 'f', 'f', 'e', 'r']

它把一个字符串"itdiffer"转化为['i', 't', 'd', 'i', 'f', 'f', 'e', 'r'],然后将这个列表作为参数,提供给extend,并将列表中的元素塞入原来的列表中。

>>> num_lst = [1,2,3]

>>> num_lst.extend(8)

Traceback (most recent call last):

File "", line 1, in

TypeError: 'int' object is not iterable

这就报错了。错误提示中告诉我们,那个数字8,是int类型的对象,不是iterable的。

这里讲述的两个让列表扩容的函数append()和extend()。从上面的演示中,可以看到他们有相同的地方:

都是原地修改列表

既然是原地修改,就不返回值

原地修改没有返回值,就不能赋值给某个变量。

>>> one = ["good","good","study"]

>>> another = one.extend(["day","day","up"]) #对于没有提供返回值的函数,如果要这样,结果是:

>>> another #这样的,什么也没有得到。

>>> one

['good', 'good', 'study', 'day', 'day', 'up']

那么两者有什么不一样呢?看下面例子:

>>> lst = [1,2,3]

>>> lst.append(["qiwsir","github"])

>>> lst

[1, 2, 3, ['qiwsir', 'github']] #append的结果

>>> len(lst)

4

>>> lst2 = [1,2,3]

>>> lst2.extend(["qiwsir","github"])

>>> lst2

[1, 2, 3, 'qiwsir', 'github'] #extend的结果

>>> len(lst2)

5

append是整建制地追加,extend是个体化扩编。

extend将它的参数视为 list,extend的行为是把这两个list接到一起,append是将它的参数视为element,作为一个整体添加上去的。

List里可以有任意的数据类型,所以,要分清这俩函数的区别。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值