我需要在Python中创建一个列表列表,所以我输入以下内容:
myList = [[1] * 4] * 3
Run Code Online (Sandbox Code Playgroud)
列表看起来像这样:
[[1, 1, 1, 1], [1, 1, 1, 1], [1, 1, 1, 1]]
Run Code Online (Sandbox Code Playgroud)
然后我改变了最里面的一个值:
myList[0][0] = 5
Run Code Online (Sandbox Code Playgroud)
现在我的列表看起来像这样:
[[5, 1, 1, 1], [5, 1, 1, 1], [5, 1, 1, 1]]
Run Code Online (Sandbox Code Playgroud)
这不是我想要或期望的.有人可以解释一下发生了什么,以及如何解决这个问题?
可能重复:
Python 2.x陷阱和地雷
今天,多年后我被可变的默认参数再次咬了.除非需要,我通常不会使用可变的默认参数,但我认为随着时间的推移我忘了这一点.今天在应用程序中,我在PDF生成函数的参数列表中添加了tocElements = [],现在每次调用"generate pdf"后,"目录"变得越来越长.:)
我还应该在我的列表中添加什么才能避免?
始终以相同的方式导入模块,例如,from y import x并将import x其视为不同的模块.
不要使用范围代替列表因为range()无论如何都将成为迭代器,以下将失败:
myIndexList = [0, 1, 3]
isListSorted = myIndexList == range(3) # will fail in 3.0
isListSorted = myIndexList == list(range(3)) # will not
Run Code Online (Sandbox Code Playgroud)
使用xrange可能会错误地做同样的事情:
myIndexList == xrange(3)
Run Code Online (Sandbox Code Playgroud)小心捕获多种异常类型:
try:
raise KeyError("hmm bug")
except KeyError, TypeError:
print TypeError
Run Code Online (Sandbox Code Playgroud)
这打印出"嗯bug",虽然它不是一个bug; 看起来我们正在捕获这两种类型的异常,但我们只将KeyError作为变量TypeError捕获,而是使用它:
try:
raise KeyError("hmm bug")
except (KeyError, TypeError):
print TypeError
Run Code Online (Sandbox Code Playgroud)