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 "<stdin>", line 1, in <module> 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 "<stdin>", line 1, in <module> 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里可以有任意的數據類型,所以,要分清這倆函數的區別。

 

 





























































































































免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM