真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

python怎樣把嵌套列表轉(zhuǎn)變成普通列表-創(chuàng)新互聯(lián)

這篇文章主要介紹了python怎樣把嵌套列表轉(zhuǎn)變成普通列表,具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

創(chuàng)新互聯(lián)堅(jiān)持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:成都做網(wǎng)站、成都網(wǎng)站制作、成都外貿(mào)網(wǎng)站建設(shè)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時(shí)代的蓬溪網(wǎng)站設(shè)計(jì)、移動(dòng)媒體設(shè)計(jì)的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!

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

思考:

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

    -- 把取出的單個(gè)值加入到新的列表中

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

  -- 當(dāng)取到最里面的列表嵌套時(shí)候,對(duì)最后一個(gè)值進(jìn)行處理

#!/usr/bin/python3
 
__author__ = 'beimenchuixue'
__blog__ = 'http://www.cnblogs.com/2bjiujiu/'
 
 
def change_l(raw_l):
  """這個(gè)函數(shù)處理列表比較特殊,必須滿足每層列表中最后一個(gè)值為嵌套列表"""
  median_l = raw_l                # 中間列表
  new_l = []                   # 結(jié)果列表
  count = 0                    # 循環(huán)計(jì)數(shù)統(tǒng)計(jì)循環(huán)次數(shù)和列表長(zhǎng)度比較的值
  while True:
    try:
      for value in median_l:         # 每次for循環(huán)取出一個(gè)值
        count += 1
        if count < len(median_l):      # 如果計(jì)算小于列表長(zhǎng)度,說明沒有取出最后的嵌套列表
          new_l.append(value)
        elif count == len(median_l):    # 當(dāng)計(jì)數(shù)長(zhǎng)度等于列表長(zhǎng)度,取出二層嵌套列表
          median_l = value        # 每次指向每一層最后的嵌套列表
          count = 0            # 計(jì)算清零
    except Exception as e:           # 打印異常
      print(e)
       
    try:
      len(median_l)              # 每次嘗試對(duì)每層最后一個(gè)值進(jìn)行取長(zhǎng),不是列表報(bào)錯(cuò),并把最后一個(gè)值添加到結(jié)果列表
    except TypeError:
      new_l.append(median_l)
      break                  # 最后一個(gè)值添加進(jìn)去,循環(huán)結(jié)束
  return new_l
 
 
if __name__ == '__main__':
  raw_l = [1, 5, 6, [2, 7, 7, [3, [4, 5, 6]]]]  # 定義一個(gè)初始嵌套列表
   
  new_l = change_l(raw_l=raw_l)
  print('change_l:', new_l)

沒有解決一個(gè)問題:

  -- 這個(gè)問題本身很特殊,有點(diǎn)遞歸嵌套,無法解決一層有2個(gè)以上的嵌套列表、

如何解決  ['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):
  """這個(gè)可以應(yīng)對(duì)各種嵌套類型列表,都可以把多維列表一維化"""
  new_l = []                   # 初始結(jié)果列表
  median_l = []                  # 循環(huán)接收取出來的嵌套列表,一個(gè)中間列表
  while True:
    for value in raw_l:
      try:
        if len(value):           # 判斷取出是否是整數(shù),是整數(shù)觸發(fā)異常,嵌套列表和字符串都有長(zhǎng)度
          try:
            if value.isalnum():     # 判斷取出是數(shù)字或字母,不是數(shù)字或字母觸發(fā)異常
              new_l.append(value)   # 是數(shù)字或字母添加到list_a中去
          except Exception as e:     # 觸發(fā)不是數(shù)字或字母異常
            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ā)整數(shù)len()方法異常
        print(e)
        new_l.append(value)         # 是整數(shù)添加到new_l中去
         
    # 判斷取到最后的嵌套列表中是否還有嵌套列表
    count = 0
    for value in median_l:           # 循環(huán)二層嵌套列表
      try:                  # 嘗試判斷最后一層嵌套列表是否嵌套,如果嵌套,異常次數(shù)就會(huì)少于列表長(zhǎng)度
        len(value)             # 整數(shù)觸發(fā)異常
        value.isalnum()           # 不是 數(shù)字或字母類型字符串觸發(fā)異常
      except Exception as e:
        print(e)
        count += 1             # 每出現(xiàn)一次異常,異常次數(shù)加1
    if count == len(median_l):         # 判斷異常次數(shù)是否等于最后循環(huán)列表長(zhǎng)度,如果等于,就確認(rèn)已經(jīng)循環(huán)了最后一層列表,退出整個(gè)循環(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'] # 初始普通嵌套列表
  # 結(jié)果
  new_l = change_l(raw_l)
  print(new_l)

邏輯整理:

  1. 本質(zhì)上通過for循環(huán)特性,for循環(huán)只能遍歷一層
  2. 通過遍歷,把取出來的單個(gè)值進(jìn)行判斷,把符合要求的加入到新的列表中,把不符合的添加到中間列表中

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

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

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“python怎樣把嵌套列表轉(zhuǎn)變成普通列表”這篇文章對(duì)大家有幫助,同時(shí)也希望大家多多支持創(chuàng)新互聯(lián),關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,更多相關(guān)知識(shí)等著你來學(xué)習(xí)!


網(wǎng)站題目:python怎樣把嵌套列表轉(zhuǎn)變成普通列表-創(chuàng)新互聯(lián)
轉(zhuǎn)載源于:http://weahome.cn/article/csjeie.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部