random.shuffle()的使用注意事项

使用random.shuffle时,如果不想打乱原有数据,一般会选择将该数据复制一遍,然而Python的话即便复制了原来的数据也会改变。如

import random

a = [0, 1, 2, 3, 4]
b = a
random.shuffle(b)
print(a)
print(b)


a = [0, 1, 2, 3, 4]
b = a[:]
random.shuffle(b)
print(a)
print(b)

上半部分输出的结果如下,可以看到,虽然我们本意只是打乱b的顺序,但是a得顺序也被打乱了。

[3, 2, 0, 4, 1]
[3, 2, 0, 4, 1]

下半部分输出数据如下,此时才是我们真正想要的结果,只有b被打乱了,a的数据还是和原来一样。

[0, 1, 2, 3, 4]
[2, 0, 4, 1, 3]

查阅之后得知,Python中有浅复制和深复制。

具体也没详细取深究,个人理解是,b=a的话,只是多了一个变量,但是指向的地址与数据是一样的,b=a[:]是将a的所有数据都切片下来,存储为b,这样才是真正的多了一个数据。

猜你喜欢

转载自blog.csdn.net/watermelon_learn/article/details/85224494