Python 默认序列是支持
+
和*
操作的。
通常+
号两侧的序列由相同类型的数据所构成,在拼接的过程中,两个被操作的序列都不会被修改,Python 会新建一个包含同样类型数据的序列来作为拼接的结果。
⚠️注意: +
和 *
都遵循这个规律,不修改原有的操作对象,而是构建一个全新的序列。
ls = [1, 2, 3]
ls_1 = [4, 5, 6]
new_ls = ls * 2 + ls_1
print(ls) # [1, 2, 3]
print(ls_1) # [4, 5, 6]
print(new_ls) # [1, 2, 3, 1, 2, 3, 4, 5, 6]
建立由列表组成的列表---引用对象可能发生的错误:
如果在 a * n
这个语句中,序列 a
里的元素是对其他可变对象的引用的话,你就需要格外注意了,因为这个式子的结果可能会出乎意料。
# 如果在 ls * n 的语句中,序列 ls 里是对其他对象的引用的话,你得到的列表里包含的3个元素其实是3个引用,而且这三个引用指向同一个列表。
# 所以当你修改了 ls 的子列表的属性的话,新列表的内容也会随之更改
a = [1, 'a']
b = [2, 'b']
# 元素是引用对象,而不是值本身
z = [a, b] * 2
print(z) # [[1, 'a'], [2, 'b'], [1, 'a'], [2, 'b']]
# 修改被引用的对象,发现1处所有,所有引用的地方都发生了变化
z[0][0] = 'z'
print(z) # [['z', 'a'], [2, 'b'], ['z', 'a'], [2, 'b']]