Python中五種列表拷貝的方法
1. 賦值操作
最容易想到的就是我們可以使用賦值操作來直接復(fù)制列表,
代碼如下:
copied_list=original_list
此時,original_list
和copyed_list
都將指向同一個列表對象。
舉例如下:
original_list=[1,2,3] #Copying list using assignment operation copied_list=original_list print(copied_list) #Output:[1, 2, 3] print(original_list) #Output:[1, 2, 3] #checking the id of both original and copied list print(id(original_list)) #Output: print(id(copied_list)) #Output:26751688
上圖可視化如下:
此時,在 original_list
中所做的修改將反映在copyed_list 中,反之亦然。
樣例代碼如下:
#modifying original_list original_list.append(99) #Output:[1, 2, 3,99] print(copied_list) #Output:[1, 2, 3,99] print(id(original_list)) #Output:26751688 print(id(copied_list)) #Output:26751688
可視化結(jié)果如下:
2. 使用copy操作
我們也可以使用 copy() 函數(shù)來復(fù)制 python 列表,此時original_list
和copyed_list
指向內(nèi)存中不同的列表對象。
樣例代碼如下:
original_list=[1,2,3] #Copying list using copy function copied_list=original_list.copy() print(copied_list) #Output:[1, 2, 3] print(original_list) #Output:[1, 2, 3] #checking the id of both original and copied list print(id(original_list)) #Output:27800264 print(id(copied_list)) #Output:27799880
可視化如下:
由于二者指向內(nèi)存不同,所以此時在原始列表中所做的修改不會反映在復(fù)制的列表中,反之亦然。
#modifying original_list original_list.append(99) print(original_list) #Output:[1, 2, 3,99] print(copied_list) #Output:[1, 2, 3] print(id(copied_list)) #Output:27799880 print(id(original_list)) #Output:27800264
可視化如下:
3. 使用list()構(gòu)造函數(shù)
我們也可以使用list()
構(gòu)造函數(shù)來復(fù)制列表。 original_list
和copyed_list
均指向不同的列表對象。代碼如下:
copied_list=list(original_list)
樣例代碼如下:
original_list=[1,2,3] #Copying list using list() constructor copied_list=list(original_list) print(copied_list) #Output:[1, 2, 3] print(original_list) #Output:[1, 2, 3] #checking the id of both original and copied list print(id(original_list)) #Output:27800264 print(id(copied_list)) #Output:27799880
此時,修改 original_list
中的元素不會反映在copyed_list
中,反之亦然。
#modifying original_list original_list.append(99) print(original_list) #Output:[1, 2, 3,99] print(copied_list) #Output:[1, 2, 3]
4. 使用索引
接著,我們可以使用索引方式來拷貝列表。
s[i:j:k] — slice of s from i to j with step k
此時,i,j,k解釋如下:
i → start index, j → end index, k → step
如果我們使用original_list[:]
,它將從頭到尾對 original_list
進行切片,并返回列表的副本。
如下所示:
copied_list=original_list[:]
接著我們來看個例子:
original_list=[1,2,3] #Copying list using INDEXING copied_list=original_list[:] print(copied_list) #Output:[1, 2, 3] print(original_list) #Output:[1, 2, 3] #checking the id of both original and copied list print(id(original_list)) #Output:27800264 print(id(copied_list)) #Output:27799880
此時,修改orignial_list
不會反映在copyed_list
中,反之亦然。
#modifying original_list original_list.append(99) print(original_list) #Output:[1, 2, 3,99] print(copied_list) #Output:[1, 2, 3] print(id(copied_list)) #Output:27799880 print(id(original_list)) #Output:27800264
5. 列表生成式
最后,我們可以使用列表生成式來復(fù)制列表中的元素,
代碼如下:
copied_list=[i for i in original_list]
我們來舉個栗子,代碼如下:
original_list=[1,2,3] #Copying list using list comprehension copied_list=[ i for i in original_list] print(copied_list) #Output:[1, 2, 3] print(original_list) #Output:[1, 2, 3] #checking the id of both original and copied list print(id(original_list)) #Output:27800264 print(id(copied_list)) #Output:27799880
此時,修改original_list
不會反映在copyed_list
中,反之亦然。
#modifying original_list original_list.append(99) print(original_list) #Output:[1, 2, 3,99] print(copied_list) #Output:[1, 2, 3] print(id(copied_list)) #Output:27799880 print(id(original_list)) #Output:27800264
6 總結(jié)
在本文中,主要介紹了在 python 中復(fù)制列表的不同方法。
- 使用賦值操作,此時兩個列表將指向同一個列表對象
- 使用索引,列表構(gòu)造函數(shù),列表生成式,copy()等方式時,兩個列表將指向不同的列表對象。
到此這篇關(guān)于Python中五種列表拷貝的方法的文章就介紹到這了,更多相關(guān)Python列表拷貝方法內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python調(diào)用系統(tǒng)底層API播放wav文件的方法
這篇文章主要介紹了Python調(diào)用系統(tǒng)底層API播放wav文件的方法,涉及Python使用pywin32調(diào)用系統(tǒng)底層API讀取與播放wav文件的相關(guān)操作技巧,需要的朋友可以參考下2017-08-08django框架中ajax的使用及避開CSRF 驗證的方式詳解
這篇文章主要介紹了django框架中ajax的使用及避開CSRF 驗證的方式,結(jié)合實例形式分析了Django框架ajax后臺交互與排除驗證csrf相關(guān)操作技巧,需要的朋友可以參考下2019-12-12LyScript實現(xiàn)對內(nèi)存堆棧掃描的方法詳解
LyScript插件中提供了三種基本的堆棧操作方法,其中push_stack用于入棧,pop_stack用于出棧,peek_stac可用于檢查指定堆棧位置處的內(nèi)存參數(shù)。所以本文將利用這一特性實現(xiàn)對內(nèi)存堆棧掃描,感興趣的可以了解一下2022-08-08