我在bleow显示的代码中使用嵌套列表在Python中遇到了一些问题。
基本上,我有一个包含所有0值的2D列表,我想循环更新列表值。
但是,Python不会产生我想要的结果。我对range()Python列表索引有误解吗?
some_list = 4 * [(4 * [0])]
for i in range(3):
for j in range(3):
some_list[i+1][j+1] = 1
for i in range(4):
print(some_list[i])
我预期的结果是:
[0, 0, 0, 0]
[0, 1, 1, 1]
[0, 1, 1, 1]
[0, 1, 1, 1]
但是Python的实际结果是:
[0, 1, 1, 1]
[0, 1, 1, 1]
[0, 1, 1, 1]
[0, 1, 1, 1]
这里发生了什么?
问题是由于python选择通过引用传递列表这一事实引起的。
通常,变量是按“值”传递的,因此它们独立运行:
>>> a = 1
>>> b = a
>>> a = 2
>>> print b
1
但是由于列表可能会变得很大,而不是将整个列表转移到内存周围,因此Python选择仅使用引用(C术语为“指针”)。如果将一个变量分配给另一个变量,则仅分配对其的引用。这意味着你可以在内存中拥有两个指向同一列表的变量:
>>> a = [1]
>>> b = a
>>> a[0] = 2
>>> print b
[2]
因此,在你的第一行代码中,你有了4 * [0]
。现在[0]
是一个指向内存中值0
的指针,将其乘以时,你将获得四个指向内存中同一位置的指针。但是,当你更改其中一个值时,Python知道指针需要更改以指向新值:
>>> a = 4 * [0]
>>> a
[0, 0, 0, 0]
>>> [id(v) for v in a]
[33302480, 33302480, 33302480, 33302480]
>>> a[0] = 1
>>> a
[1, 0, 0, 0]
当你将此列表相乘时,就会出现问题-你获得了四个列表指针副本。现在,当你更改一个列表中的值之一时,所有四个都一起更改:
>>> a[0][0] = 1
>>> a
[[1, 0, 0, 0], [1, 0, 0, 0], [1, 0, 0, 0], [1, 0, 0, 0]]
解决方案是避免第二次乘法。循环可以完成这项工作:
>>> some_list = [(4 * [0]) for _ in range(4)]
问题内容: 谁能告诉我如何在嵌套列表中调用索引? 通常我只写: 但是如果我有一个带有嵌套列表的列表,如下所示: 我想分别浏览每个索引? 问题答案: 如果您确实需要索引,则可以按照内部列表再次执行以下操作: 但是遍历列表本身是更pythonic的: 如果您确实需要索引,也可以使用:
问题内容: python初学者在这里。 我有2个要合并的嵌套列表: 我正在寻找的输出是: 可以在没有任何外部库的情况下完成此操作吗?注意:len(list1)= len(list2) 问题答案: 使用函数的功能并列出理解:
问题内容: 我有这个嵌套列表: 现在,我要做的是将列表中的每个元素转换为float。我的解决方案是这样的: 但这可以使用嵌套列表理解来完成吗? 我所做的是: 但是结果是一堆100的总数为2400。 任何解决方案,解释将不胜感激。谢谢! 问题答案: 这是使用嵌套列表理解的方法: 这将为你提供一个列表列表,与你开始时的列表类似,只是使用浮点数而不是字符串。如果你想要一个固定列表,则可以使用。
问题内容: 我想复制一个2D列表,以便如果我修改一个列表,则不修改另一个列表。 对于一维列表,我只是这样做: 现在,如果我修改了b,a就不会修改。 但这不适用于二维列表: 如果我修改了b,a也会被修改。 我该如何解决? 问题答案: 对于不管尺寸多少都可以工作的更通用的解决方案,请使用:
假设我期望一个列表列表,其中内部列表具有不同的类型和长度,例如。G 如何使用argparse解析上述列表? 关于stackoverflow最有用的问题: 类似的问题也存在,最有用的问题在这里。但是在我的例子中,它们还不够好,因为它们忽略了列表嵌套了不同的数据类型和长度的事实。
本文向大家介绍Markdown 嵌套列表,包括了Markdown 嵌套列表的使用技巧和注意事项,需要的朋友参考一下 示例 列表可以嵌套 八个空间 十二个空格 四个空间 然后回来