我试着写了一些代码:

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.append(l)代替j[k] = l,并完全避免k。


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.append(l)

同时也要避免使用小写的“L”,因为它们很容易与“1”混淆


你的另一个选择是初始化j:

j = [None] * len(i)

你也可以使用列表推导式:

j = [l for l in i]

或者用下面的语句复制一份:

j = i[:]

还有一种方法:

j=i[0]
for k in range(1,len(i)):
    j = numpy.vstack([j,i[k]])

在这种情况下,j将是一个numpy数组


我认为Python方法insert就是你要找的:

将元素x插入位置i。 list.insert (i (x)

array = [1,2,3,4,5]
# array.insert(index, element)
array.insert(1,20)

print(array)

# prints [1,20,2,3,4,5]

对于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}

也许你需要extend()

i=[1,3,5,7]
j=[]
j.extend(i)