黄色网页视频 I 影音先锋日日狠狠久久 I 秋霞午夜毛片 I 秋霞一二三区 I 国产成人片无码视频 I 国产 精品 自在自线 I av免费观看网站 I 日本精品久久久久中文字幕5 I 91看视频 I 看全色黄大色黄女片18 I 精品不卡一区 I 亚洲最新精品 I 欧美 激情 在线 I 人妻少妇精品久久 I 国产99视频精品免费专区 I 欧美影院 I 欧美精品在欧美一区二区少妇 I av大片网站 I 国产精品黄色片 I 888久久 I 狠狠干最新 I 看看黄色一级片 I 黄色精品久久 I 三级av在线 I 69色综合 I 国产日韩欧美91 I 亚洲精品偷拍 I 激情小说亚洲图片 I 久久国产视频精品 I 国产综合精品一区二区三区 I 色婷婷国产 I 最新成人av在线 I 国产私拍精品 I 日韩成人影音 I 日日夜夜天天综合

python如何把嵌套列表轉變成普通列表

系統(tǒng) 2024 0

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

思考:

  -- for循環(huán)每次都遍歷列表一層

    -- 把取出的單個值加入到新的列表中

    -- 把取出來的嵌套列表變成新的遍歷列表,就需要在for循環(huán)外嵌套一個while循環(huán)

  -- 當取到最里面的列表嵌套時候,對最后一個值進行處理

            
#!/usr/bin/python3
 
__author__ = 'beimenchuixue'
__blog__ = 'http://www.cnblogs.com/2bjiujiu/'
 
 
def change_l(raw_l):
  """這個函數處理列表比較特殊,必須滿足每層列表中最后一個值為嵌套列表"""
  median_l = raw_l                # 中間列表
  new_l = []                   # 結果列表
  count = 0                    # 循環(huán)計數統(tǒng)計循環(huán)次數和列表長度比較的值
  while True:
    try:
      for value in median_l:         # 每次for循環(huán)取出一個值
        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                  # 最后一個值添加進去,循環(huán)結束
  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 = []                  # 循環(huán)接收取出來的嵌套列表,一個中間列表
  while True:
    for value in raw_l:
      try:
        if len(value):           # 判斷取出是否是整數,是整數觸發(fā)異常,嵌套列表和字符串都有長度
          try:
            if value.isalnum():     # 判斷取出是數字或字母,不是數字或字母觸發(fā)異常
              new_l.append(value)   # 是數字或字母添加到list_a中去
          except Exception as e:     # 觸發(fā)不是數字或字母異常
            print(e)
            median_l.extend(value)   # 把取出的嵌套列表添加到 median_l 中
            raw_l = median_l      # 循環(huán)raw_l 指向 median_l 中間列表
            print(raw_l)
      except Exception as e:         # 觸發(fā)整數len()方法異常
        print(e)
        new_l.append(value)         # 是整數添加到new_l中去
         
    # 判斷取到最后的嵌套列表中是否還有嵌套列表
    count = 0
    for value in median_l:           # 循環(huán)二層嵌套列表
      try:                  # 嘗試判斷最后一層嵌套列表是否嵌套,如果嵌套,異常次數就會少于列表長度
        len(value)             # 整數觸發(fā)異常
        value.isalnum()           # 不是 數字或字母類型字符串觸發(fā)異常
      except Exception as e:
        print(e)
        count += 1             # 每出現一次異常,異常次數加1
    if count == len(median_l):         # 判斷異常次數是否等于最后循環(huán)列表長度,如果等于,就確認已經循環(huán)了最后一層列表,退出整個循環(huán)
      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循環(huán)特性,for循環(huán)只能遍歷一層
  2. 通過遍歷,把取出來的單個值進行判斷,把符合要求的加入到新的列表中,把不符合的添加到中間列表中

最大問題: 如何進行最后的循環(huán)的判斷?

  我的想法是:
    a. 通過最后中間列表的遍歷,判斷是否還有嵌套列表,通過異常次數和列表長度比較,
    b. 如果中間列表等于異常次數,說明循環(huán)到了最后的列表,退出整個循環(huán)

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發(fā)表我的評論
最新評論 總共0條評論