python 嵌套列表创建

博客介绍了Python列表初始化及修改的相关内容。通过*初始化列表会出现修改一个子列表,其他子列表也跟着改变的问题,原因是子元素指向同一对象。还给出了解决办法,即使用列表推导来避免该问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.初始化列表及修改

    初始化列表有很多方法,其中之一可以通过*来初始化:

a = [[]]*3

print a

>>> [[], [], []]

通过这个方法获取了一个包含三个空list的嵌套列表,下面对这个列表进行修改:

a[0].append(1)

print a

>>> [[1], [1], [1]]

通过输出,我们发现我们只是修改了a[0], 为什么a里的子列表全部都被修改了,接下来通过内置函数id来查看一下a的子元素的内存地址(通过这个可以知道是否是同一个对象,id值相同,则为同一个对象)。

print id(a[0])

print id(a[1])

print id(a[2])

>>> 43106552

>>> 43106552

>>> 43106552

原来问题出在这里,通过,a列表中的子元素统统指向同一个对象,不管修改其中的哪个子元素都会导致其它子元素跟着一起修改(当然前提是子元素都是可变元素,如果保存的是字符串等不可变元素就另当别论了)。

a = [1] * 3

print a

print id(a[0]), id(a[1]), id(a[2])

a[1] = 100

print a

print id(a[0]), id(a[1]), id(a[2])


# output

>>> [1, 1, 1]

>>> 35117232 35117232 35117232

>>> [1, 100, 1]

>>> 35117232 35118028 35117232

 

2.如何解决

可以通过列表推导解决上面的问题:


a = [[] for _ in range(3)]

print id(a[0]), id(a[1]), id(a[2])


#output

>>> 40111280 40111360 40111320

 

### Python嵌套列表的操作 #### 创建嵌套列表Python中,可以通过简单地将一个列表作为另一个列表的元素来创建嵌套列表。下面是一个简单的例子: ```python nested_list = [[1, 2], [3, 4], [5, 6]] print(nested_list) ``` 这段代码定义了一个名为`nested_list`的变量,该变量包含了三个子列表,每个子列表又分别含有两个整数[^1]。 #### 访问嵌套列表中的元素 访问嵌套列表内的特定项需要指定多个索引位置。例如,获取上述`nested_list`的第一个子列表的第一项可以这样写: ```python first_item = nested_list[0][0] print(first_item) # 输出: 1 ``` 此命令先选取最外层列表的第一个成员(即第一个方括号),再从中提取其首个元素(第二个方括号)。 #### 使用列表推导式处理嵌套列表 对于较为复杂的转换任务,比如扁平化一个多维数组或将某些条件应用于内部项目,则可利用列表推导式的强大功能。考虑如下情况——我们需要从上面提到过的`nested_list`里筛选出所有的偶数值并构建一个新的单一维度列表: ```python flattened_evens = [item for sublist in nested_list for item in sublist if item % 2 == 0] print(flattened_evens) # 结果应为:[2, 4, 6] ``` 这里采用了双重循环机制:外部迭代器遍历各个子列表(`for sublist in nested_list`);内部则逐一遍历这些子集里的每一项(`for item in sublist`),同时附加过滤条件(`if item % 2 == 0`)以只保留符合条件的结果。 #### 嵌套列表去重且保持原有顺序 为了去除重复条目而不改变原始排列次序,一种常见做法是从左至右扫描整个序列,在遇见未曾见过的新值时将其加入到结果集中。这可以通过组合使用集合(set)与列表(list)数据类型完成,但也可以采用基于pop()和insert()的方法实现更为精细控制下的操作[^3]: ```python def remove_duplicates_preserve_order(lst): seen = set() result = [] for element in lst: if isinstance(element, list): # 如果当前元素本身也是一个列表... inner_result = remove_duplicates_preserve_order(element) # ...递归调用函数处理这个内含表单. if inner_result not in seen: seen.add(tuple(inner_result)) # 将内部列表转成不可变形式存入set防止后续比较过程中发生错误. result.append(inner_result) elif element not in seen: seen.add(element) result.append(element) return result original_nested_list = [[1, 2], [2, 3], [1, 2], [4, 5]] cleaned_up_list = remove_duplicates_preserve_order(original_nested_list) print(cleaned_up_list) # 应显示[[1, 2], [2, 3], [4, 5]], 并维持最初出现的位置关系. ``` 在这个版本中,程序会检查每一个遇到的对象是否已经存在于记录已见项目的集合seen之中;如果不是,则会被追加到最终输出列表result里面,并更新seen的内容以防将来再次遭遇相同实例。值得注意的是,针对那些本身就是列表类型的对象,还需要额外一层逻辑来进行深拷贝以及相应调整以便于正确存储和对比。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值