网络编程
位置:首页>> 网络编程>> Python编程>> python如何把嵌套列表转变成普通列表

python如何把嵌套列表转变成普通列表

作者:lijiao  发布时间:2023-08-20 14:28:19 

标签:python,嵌套列表,普通列表

如何把[1, 5, 6, [2, 7, [3, [4, 5, 6]]]]变成[1, 5, 6, 2, 7, 3, 4, 5, 6]?

思考:

-- for循环每次都遍历列表一层

-- 把取出的单个值加入到新的列表中

-- 把取出来的嵌套列表变成新的遍历列表,就需要在for循环外嵌套一个while循环

-- 当取到最里面的列表嵌套时候,对最后一个值进行处理


#!/usr/bin/python3

__author__ = 'beimenchuixue'
__blog__ = 'http://www.cnblogs.com/2bjiujiu/'

def change_l(raw_l):
 """这个函数处理列表比较特殊,必须满足每层列表中最后一个值为嵌套列表"""
 median_l = raw_l                # 中间列表
 new_l = []                   # 结果列表
 count = 0                    # 循环计数统计循环次数和列表长度比较的值
 while True:
   try:
     for value in median_l:         # 每次for循环取出一个值
       count += 1
       if count < len(median_l):      # 如果计算小于列表长度,说明没有取出最后的嵌套列表
         new_l.append(value)
       elif count == len(median_l):    # 当计数长度等于列表长度,取出二层嵌套列表
         median_l = value        # 每次指向每一层最后的嵌套列表
         count = 0            # 计算清零
   except Exception as e:           # 打印异常
     print(e)

try:
     len(median_l)              # 每次尝试对每层最后一个值进行取长,不是列表报错,并把最后一个值添加到结果列表
   except TypeError:
     new_l.append(median_l)
     break                  # 最后一个值添加进去,循环结束
 return new_l

if __name__ == '__main__':
 raw_l = [1, 5, 6, [2, 7, 7, [3, [4, 5, 6]]]]  # 定义一个初始嵌套列表

new_l = change_l(raw_l=raw_l)
 print('change_l:', new_l)

没有解决一个问题:

-- 这个问题本身很特殊,有点递归嵌套,无法解决一层有2个以上的嵌套列表、

如何解决  ['a', 'b', 1, ['c', [2, 'd'], 3, 4, 5, ['e', 6, 'f', 'E'], 7], 8] 变成普通列表?


#!/usr/bin/python3

__author__ = 'beimenchuixue'
__blog__ = 'http://www.cnblogs.com/2bjiujiu/'

def change_l(raw_l):
 """这个可以应对各种嵌套类型列表,都可以把多维列表一维化"""
 new_l = []                   # 初始结果列表
 median_l = []                  # 循环接收取出来的嵌套列表,一个中间列表
 while True:
   for value in raw_l:
     try:
       if len(value):           # 判断取出是否是整数,是整数触发异常,嵌套列表和字符串都有长度
         try:
           if value.isalnum():     # 判断取出是数字或字母,不是数字或字母触发异常
             new_l.append(value)   # 是数字或字母添加到list_a中去
         except Exception as e:     # 触发不是数字或字母异常
           print(e)
           median_l.extend(value)   # 把取出的嵌套列表添加到 median_l 中
           raw_l = median_l      # 循环raw_l 指向 median_l 中间列表
           print(raw_l)
     except Exception as e:         # 触发整数len()方法异常
       print(e)
       new_l.append(value)         # 是整数添加到new_l中去

# 判断取到最后的嵌套列表中是否还有嵌套列表
   count = 0
   for value in median_l:           # 循环二层嵌套列表
     try:                  # 尝试判断最后一层嵌套列表是否嵌套,如果嵌套,异常次数就会少于列表长度
       len(value)             # 整数触发异常
       value.isalnum()           # 不是 数字或字母类型字符串触发异常
     except Exception as e:
       print(e)
       count += 1             # 每出现一次异常,异常次数加1
   if count == len(median_l):         # 判断异常次数是否等于最后循环列表长度,如果等于,就确认已经循环了最后一层列表,退出整个循环
     break
   median_l = []                # 置空中间列表,接收下一层嵌套列表
 return new_l

if __name__ == '__main__':
 raw_l = ['a', 'b', 1, ['c', [2, 'd'], 3, 4, 5, ['e', 6, 'f', 'E'], 7], 8, 'g'] # 初始普通嵌套列表
 # 结果
 new_l = change_l(raw_l)
 print(new_l)

逻辑整理:

1. 本质上通过for循环特性,for循环只能遍历一层
2. 通过遍历,把取出来的单个值进行判断,把符合要求的加入到新的列表中,把不符合的添加到中间列表中

最大问题:如何进行最后的循环的判断?

我的想法是:
a. 通过最后中间列表的遍历,判断是否还有嵌套列表,通过异常次数和列表长度比较,
b. 如果中间列表等于异常次数,说明循环到了最后的列表,退出整个循环

0
投稿

猜你喜欢

  • 1、前言在Python中元组是一个和列表非常类似的数据类型,不同之处就是列表中的元素可以修改,而元组之中的元素不可以修改。2、定义和使用元组
  • 如何生成斐波那契數列斐波那契(Fibonacci)數列是一个非常简单的递归数列,除第一个和第二个数外,任意一个数都可由前两个数相加得到。用计
  • Python 如何转换string到float?简单几步,让你轻松解决。打开软件,新建python项目,如图所示右键菜单中创建.py文件,如
  • Object 类型的对象虽然有 toString 方法,但结果却是 [Object Object] 让人没法理解的字符。比如简单的对象:{n
  • 时间久了,注册用户和朋友数据库里的废记录渐渐多了起来,尤其是电子邮件地址,请问有什么好的办法可以快速安全地将它们删除吗?试试下面这个办法,它
  • PHP levenshtein() 函数实例计算两个字符串之间的 Levenshtein 距离:<?php echo levensht
  • 本文使用的是163邮件进行测试。注:163邮箱现在需要使用 客户端授权码 进行测试,不再支持邮箱密码进行测试。 
  • 下面十条内容的标题原本是《10 Lessons for Young Designers》,是John C. Jay给年青设计师们的十条经验教
  • 说起页面执行时间相信大家并不陌生,如果你经常逛论坛,就会发现很多论坛底部都显示有页面执行时间,那么什么是页面执行时间呢?我个人理解是一个网页
  • 前言:NumPy 是 Python 语言的一个扩充程序库,支持大量高维度数组与矩阵运算,此外也针对数组运算提供大量的数学函数库。同时NumP
  • 本文实例为大家分享了利用opencv实现SIFT特征提取与匹配的具体代码,供大家参考,具体内容如下1、SIFT1.1、sift的定义SIFT
  • 本讲的内容是使用ASP的ActiveX Server Components(组件),说实话下面的内置组件我们用的很少。一、 Browser
  • //1、运行到C盘根目录 //2、输入:SET ORACLE_SID = 你的SID名称 3、输入:sqlplus/nolog 4、输入:c
  • 有没有办法更快一点? 有没有办法一次性收缩所有数据库? 代码如下:alter database 数据库名 set recovery simp
  • 关于cookie和session估计很多程序员面试的时候都会被问到,这两个概念在写web以及爬虫中都会涉及,并且两者可能很多人直接回答也不好
  • 开门见山,直接使用 skimage 库为图像添加高斯噪声是很简单的:import skimageorigin = skimage.io.im
  • 定位原理很简单,故不赘述,直接上源码,内附注释。(如果对您的学习有所帮助,还请帮忙点个赞,谢谢了)#!/usr/bin/env python
  • Python是跨平台的,免费开源的一门计算机编程语言。是一种面向对象的动态类型语言,最初被设计用于编写自动化脚本(shell),随着版本的不
  • 1. self, cls 不是关键字 在python里面,self, cls 不是关键字,完全可以使用自己写的任意变量代替实现一样的效果 代
  • 深底色风格的页面设计很受欢迎,它可以创造出别致优雅、极富创造力的效果。深底色设计适用于许多网站类型,但并非所有。这种风格应该在恰当的条件下使
手机版 网络编程 asp之家 www.aspxhome.com