我试着写了一些代码:
i = [1, 2, 3, 5, 8, 13]
j = []
k = 0
for l in i:
j[k] = l
k += 1
但是我得到一条错误消息,说IndexError: list赋值索引超出范围,指向代码的j[k] = l行。为什么会出现这种情况?我该怎么解决呢?
我试着写了一些代码:
i = [1, 2, 3, 5, 8, 13]
j = []
k = 0
for l in i:
j[k] = l
k += 1
但是我得到一条错误消息,说IndexError: list赋值索引超出范围,指向代码的j[k] = l行。为什么会出现这种情况?我该怎么解决呢?
当前回答
还有一种方法:
j=i[0]
for k in range(1,len(i)):
j = numpy.vstack([j,i[k]])
在这种情况下,j将是一个numpy数组
其他回答
j.append(l)
同时也要避免使用小写的“L”,因为它们很容易与“1”混淆
J是一个空列表,但您尝试在第一次迭代中写入元素[0],该元素还不存在。
尝试下面的方法,在列表的末尾添加一个新元素:
for l in i:
j.append(l)
当然,如果您只想复制一个现有的列表,那么在实践中永远不会这样做。你只需要这样做:
j = list(i)
或者,如果你想像使用其他语言中的数组一样使用Python列表,那么你可以预先创建一个列表,将其元素设置为空值(在下面的例子中为None),然后覆盖特定位置的值:
i = [1, 2, 3, 5, 8, 13]
j = [None] * len(i)
#j == [None, None, None, None, None, None]
k = 0
for l in i:
j[k] = l
k += 1
需要意识到的是,列表对象不允许为不存在的索引赋值。
还有一种方法:
j=i[0]
for k in range(1,len(i)):
j = numpy.vstack([j,i[k]])
在这种情况下,j将是一个numpy数组
对于j,可以使用字典(类似于关联数组)
i = [1, 2, 3, 5, 8, 13]
j = {} #initiate as dictionary
k = 0
for l in i:
j[k] = l
k += 1
print(j)
将打印:
{0: 1, 1: 2, 2: 3, 3: 5, 4: 8, 5: 13}
用j.append(l)代替j[k] = l,并完全避免k。