我正在http://openbookproject.net/thinkcs/python/english2e/ch09.html上练习#9,并遇到了一些没有意义的事情.
练习建议使用copy.deepcopy()我的任务更容易,但我不知道它怎么可能.
def add_row(matrix):
"""
>>> m = [[0, 0], [0, 0]]
>>> add_row(m)
[[0, 0], [0, 0], [0, 0]]
>>> n = [[3, 2, 5], [1, 4, 7]]
>>> add_row(n)
[[3, 2, 5], [1, 4, 7], [0, 0, 0]]
>>> n
[[3, 2, 5], [1, 4, 7]]
"""
import copy
# final = copy.deepcopy(matrix) # first way
final = matrix[:] # second way
li = []
for i in range(len(matrix[0])):
li.append(0)
# return final.append(li) # why doesn't this work?
final.append(li) # but this does
return final
Run Code Online (Sandbox Code Playgroud)
我很困惑为什么这本书建议deepcopy()在简单list[:]复制时使用它.我用错了吗?我的功能完全没有了吗?
我也有一些混乱的返回值.问题是上面代码中的文档.
TIA
Mic*_*zek 23
你问了两个问题:
matrix[:]是一个浅层副本 - 它只复制直接存储在其中的元素,并且不会递归地复制数组或其他引用本身的元素.这意味着:
a = [[4]]
b = a[:]
a[0].append(5)
print b[0] # Outputs [4, 5], as a[0] and b[0] point to the same array
Run Code Online (Sandbox Code Playgroud)
如果您存储了一个对象,也会发生同样的情况a.
deepcopy()当然,它是一个深层副本 - 它以递归方式复制每个元素,一直到树下:
a = [[4]]
c = copy.deepcopy(a)
a[0].append(5)
print c[0] # Outputs [4], as c[0] is a copy of the elements of a[0] into a new array
Run Code Online (Sandbox Code Playgroud)
return final.append(li)与调用append和返回不同,final因为list.append不返回列表对象本身,它返回None