python深拷貝和淺拷貝

2021-09-24 20:32:55 字數 4348 閱讀 2706

copy.copy 淺拷貝 只拷貝父物件,不會拷貝物件的內部的子物件。(比深拷貝更加節省記憶體)

copy.deepcopy 深拷貝 拷貝物件及其子物件

用乙個簡單的例子說明如下:

import copy公升

a = [1, 2, 3, 4, [『a』, 『b』, 『c』]]

b = a

c = copy.copy(a)

d = copy.deepcopy(a)

很容易理解:a是乙個列表,表內元素a[4]也是乙個列表(也就是乙個內部子物件);b是對a列表的又乙個引用,所以a、b是完全相同的,可以通過id(a)==id(b)證明。

id(a)

19276104

id(b)

19276104

id(d)

19286976

至於如何看深/淺拷貝的區別,可以通過下面的操作來展現:

這時再檢視結果:

a

[1, 2, 0, 4, [『a』, 『b』, 『c』, 『hello』], 5]

b

[1, 2, 0, 4, [『a』, 『b』, 『c』, 『hello』], 5]

c

[1, 2, 3, 4, [『a』, 『b』, 『c』, 『hello』]]

d

[1, 2, 3, 4, [『a』, 『b』, 『c』]]

可以發現a、b受了操作1、2的影響,c只受操作2影響,d不受影響。a、b結果相同很好理解。由於c是a的淺拷貝,只拷貝了父物件,因此a的子物件( [『a』, 『b』, 『c』, 『hello』])改變時會影響到c;d是深拷貝,完全不受a的影響

#!/usr/bin/env python3

#antuor:alan

import copy

print(』-----------------------------------數字---------------------------------』)

a1 = 123 ###賦值

a2 = 123

print (id(a1))

print (『數字賦值:』,id(a2))

print(』-----------------------------------字串---------------------------------』)

a3 = 『asd』

a4 =a3

print (id(a3))

print (『字串賦值:』,id(a4))

print(』-----------------------------------數字,字串深淺拷貝---------------------------------』)

a5 = 『alan』

a6 =copy.copy(a5) ###淺拷貝

a7 =copy.deepcopy(a5) ###深拷貝

print (id(a5))

print (『字串淺拷貝:』,id(a6))

print (『字串深拷貝:』,id(a7))

「」「字串和數字,對這三種方法,用的是同乙個記憶體位址」""

print(』-----------------------------------元祖,列表,字典---------------------------------』)

print(』---------------------字典-------------------------』)

n1 =

n2 =n1

print(id(n1))

print(『字典賦值:』,id(n2))

n3 = copy.copy(n1) ###只拷貝第一層

n4 = copy.deepcopy(n1) ###深拷貝

print(『字典淺拷貝:』,id(n3))

print(『字典深拷貝:』,id(n4))

print(』---------------------第1層-------------------------』)

print(id(n1[『k1』]))

print(『深淺拷貝第一層:』,id(n3[『k1』]))

print(『深淺拷貝第一層:』,id(n4[『k1』]))

print(』---------------------第2層-------------------------』)

print(id(n1[『k3』][1]))

print(『淺拷貝第二層:』,id(n3[『k3』][1]))

print(『深拷貝第二層:』,id(n4[『k3』][1]))

print(』-----------------------------------淺拷貝應用---------------------------------』)

dic =

print(「原資料:」,dic)

new_copy_dic = copy.copy(dic)

new_copy_dic[『cpu』][0] = 50 ###因為新資料是對舊資料的淺拷貝,只拷貝父物件,不拷貝子物件,所以新子物件變影響舊,舊子物件影響新

print(「淺拷貝後原資料:」,dic)

print(「淺拷貝資料:」,new_copy_dic)

print(』-----------------------------------深拷貝應用---------------------------------』)

#################################應用: 深拷貝###########################

dic =

print(「原資料:」,dic)

new_deepcopy_dic = copy.deepcopy(dic)

new_deepcopy_dic[『cpu』] = 90

print(「深拷貝後原資料:」,dic)

print(「深拷貝資料:」,new_deepcopy_dic)

淺拷貝是指拷貝的只是原物件元素的引用,換句話說,淺拷貝產生的物件本身是新的,但是它的內容不是新的,只是對原物件的乙個引用。這裡有個例子

alist=[[1, 2], 3, 4]

blist = alist[:] #利用切片完成一次淺拷貝

id(alist)

3084416588l

id(blist)

3084418156l

alist[0][0] = 5

alist

[[5, 2], 3, 4]

blist

[[5, 2], 3, 4]

可以看到,淺拷貝生產了乙個新的物件blist,但是alist的內容確實對alist的引用,所以但改變alist中值的時候,blist的值也跟著變化了。

alist = [1, 2]

blist = alist[:]

blist

[1, 2]

alist

[1, 2]

alist[1]=111

alist

[1, 111]

blist

[1, 2]

為什麼blist的第二個元素沒有變成111呢?因為數字在python中是不可變型別!!

這個順便回顧下python標準型別的分類:

可變型別: 列表,字典

不可變型別:數字,字串,元組

理解了淺拷貝,深拷貝是什麼自然就很清楚了。

python中有乙個模組copy,deepcopy函式用於深拷貝,copy函式用於淺拷貝。

最後,物件的賦值是深拷貝還是淺拷貝?

物件賦值實際上是簡單的物件引用

a = 1

id(a)

135720760

b = a

id(b)

135720760

a和b完全是一回事

python 深拷貝 Python深拷貝和淺拷貝!

在python中,物件賦值實際上是物件的引用。當建立乙個物件,然後把它賦給另乙個變數的時候,python並沒有拷貝這個物件,而只是拷貝了這個物件的引用 一般有三種方法,alist 1,2,3,a b 1 直接賦值 b alist,預設淺拷貝傳遞物件的引用而已,原始列表改變,被賦值的b也會做相同的改變...

Python 深拷貝和淺拷貝

淺拷貝只拷貝了引用,並沒有拷貝內容,相當於把原來的引用複製了乙份給新的變數 深拷貝是將原來的值複製了乙份到新的地方 in 30 a 1,2,3 in 31 b a in 32 id a out 32 140618626865352 in 33 id b out 33 140618626865352 ...

Python 深拷貝和淺拷貝

python深拷貝和淺拷貝的區別在於淺拷貝拷貝的是引用位址,深拷貝是複製了值 在淺拷貝時,拷貝出來的新物件的位址和原物件是不一樣的,但是新物件裡面的可變元素 如列表 的位址和原物件裡的可變元素的位址是相同的,也就是說淺拷貝它拷貝的是淺層次的資料結構 不可變元素 物件裡的可變元素作為深層次的資料結構並...