【Python】关于列表生成的坑

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/Laox1ao/article/details/81545522

生成列表

今天碰到一个巨坑。。关于python列表生成,需求是我要生成一个特定长度的列表,列表中的元素为空列表,即下面的形式:

[[],[],...,[]]

然后需要往不同的空列表中填充不同的数据,一般有下列方法:

方法1:列表表达式

list_1 = [[] for _ in range(N)]

方法2:map

list_2 = map(lambda x: [],range(N))

方法3:列表运算。。

list_3 = [[]]*N

最终,不知为何当时我选择了方法3,然后在往列表中每一个空列表填充不同的内容后,发现所有的空列表中都同时填入了一样的值。。。原因猜到了吧,前两种方法都是生成新的空列表,而第三种方法只是把一个空列表浅复制了一边,虽然是N个空列表,但是都是同一个列表的引用。。折腾了将近一个小时才找到BUG,钉在这了。。

猜你喜欢

转载自blog.csdn.net/Laox1ao/article/details/81545522
今日推荐