解决Python使用列表副本的问题
要使用一个列表的副本,要用切片进行列表复制,这样会形成两个独立的列表。
切记不要将列表赋值给一个列表,因为这样并不能得到两个列表。
1、使用赋值语法创建列表副本的问题
下边就将列表赋值,验证是否形成独立的列表:
squares = list(range(1, 11)) print('squares原始值为:', end='') print(squares) # 使用列表赋值 numbers_squares = squares print('numbers_squares所有元素为:', end='') print(numbers_squares) # 为squares列表添加数字100 squares.append(100) print('添加数字后的squares值:', end='') print(squares) # 为squares列表添加数字200 numbers_squares.append(200) print('添加数字后的number_squares值:', end='') print(numbers_squares)
输出为:
squares原始值为:[1, 2, 3, 4, 5, 6, 7, 8, 9, 10] numbers_squares所有元素为:[1, 2, 3, 4, 5, 6, 7, 8, 9, 10] 添加数字后的squares值:[1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 100] 添加数字后的number_squares值:[1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 100, 200]
可以看到,number_squares列表值中,也有数字100,说明赋值并没有形成两个独立的列表。赋值只是让Python新变量number_squares关联到包含在squares中的列表,所以这两个列表指向同一个列表。
2、列表副本正确方法:使用切片复制列表副本
下边的列子,创建一个1-10的数字列表,用切片进行列表复制形成两个独立的列表
squares = list(range(1, 11)) print('squares原始值为:', end=' ') print(squares) # 使用切片复制squares列表 numbers_squares = squares[:] print('numbers_squares所有元素为:', end=' ') print(numbers_squares)
输出为:
squares原始值为: [1, 2, 3, 4, 5, 6, 7, 8, 9, 10] numbers_squares所有元素为: [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
为了验证确实形成了两个独立的列表,在每个列表上加数字,核实每个列表都记录了加的数字
squares = list(range(1, 11)) print('squares原始值为:', end='') print(squares) # 使用切片复制squares列表 numbers_squares = squares[:] print('numbers_squares所有元素为:', end='') print(numbers_squares) # 为squares列表添加数字100 squares.append(100) print('添加数字后的squares值:', end='') print(squares) # 为squares列表添加数字200 numbers_squares.append(200) print('添加数字后的number_squares值:', end='') print(numbers_squares)
输出为:
squares原始值为:[1, 2, 3, 4, 5, 6, 7, 8, 9, 10] numbers_squares所有元素为:[1, 2, 3, 4, 5, 6, 7, 8, 9, 10] 添加数字后的squares值:[1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 100] 添加数字后的number_squares值:[1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 200]
可以看到,确实100和200分别加入到相应列表中。
以上这篇解决Python使用列表副本的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
python利用Appium实现自动控制移动设备并提取数据功能
这篇文章主要介绍了python利用Appium自动控制移动设备并提取数据,本文以控制抖音app滑动并获取抖音短视频发布者为例,通过实例代码给大家介绍的非常详细,需要的朋友可以参考下2021-09-09Python将Excel表格按某列拆分为多个sheet实现过程
这篇文章主要为大家介绍了Python实现将Excel表格按某列拆分为多个sheet,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪2023-05-05
最新评论