鉴于:
>>> li=[1,2,3]
Run Code Online (Sandbox Code Playgroud)
实际上只有两种情况需要考虑。
1) 如果一个切片超出了列表的末尾,它将传递定义的元素和一个空列表的重叠,而不会出错:
>>> li[2:]
[3]
>>> li[3:]
[]
>>> li[5555:]
[]
>>> li[1:55555]
[2, 3]
>>> li[555:55555]
[]
Run Code Online (Sandbox Code Playgroud)
2) 给定一个切片赋值,重叠元素被替换,其余元素被无误地追加:
>>> li[1:5]=[12,13,14,15,16]
>>> li
[1, 12, 13, 14, 15, 16, 15]
>>> li[555:556]=[555,556]
>>> li
[1, 12, 13, 14, 15, 16, 15, 555, 556]
Run Code Online (Sandbox Code Playgroud)
那里的最后一种情况,切片分配是对不存在的元素,因此只是附加到现有元素。
但是,如果右侧切片与左侧的现有元素不匹配,则可以有一个ValueError带有扩展切片的非现有元素(即,如果您有list_object[start:stop:step]):
>>> li
[1, 2, 3]
>>> li[1:7:2]=range(4)
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
ValueError: attempt to assign sequence of size 4 to extended slice of size 1
Run Code Online (Sandbox Code Playgroud)
但如果它们存在,您可以进行扩展切片分配:
>>> li=['X']*10
>>> li
['X', 'X', 'X', 'X', 'X', 'X', 'X', 'X', 'X', 'X']
>>> li[1:10:2]=range(5)
>>> li
['X', 0, 'X', 1, 'X', 2, 'X', 3, 'X', 4]
Run Code Online (Sandbox Code Playgroud)
大多数时候——它按预期工作。如果要使用步骤进行分配,元素需要存在。