python如何把嵌套列表轉(zhuǎn)變成普通列表
如何把[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í)候,對最后一個(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ù)和列表長度比較的值 while True: try: for value in median_l: # 每次for循環(huán)取出一個(gè)值 count += 1 if count < len(median_l): # 如果計(jì)算小于列表長度,說明沒有取出最后的嵌套列表 new_l.append(value) elif count == len(median_l): # 當(dāng)計(jì)數(shù)長度等于列表長度,取出二層嵌套列表 median_l = value # 每次指向每一層最后的嵌套列表 count = 0 # 計(jì)算清零 except Exception as e: # 打印異常 print(e) try: len(median_l) # 每次嘗試對每層最后一個(gè)值進(jìn)行取長,不是列表報(bào)錯,并把最后一個(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)對各種嵌套類型列表,都可以把多維列表一維化""" new_l = [] # 初始結(jié)果列表 median_l = [] # 循環(huán)接收取出來的嵌套列表,一個(gè)中間列表 while True: for value in raw_l: try: if len(value): # 判斷取出是否是整數(shù),是整數(shù)觸發(fā)異常,嵌套列表和字符串都有長度 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ù)就會少于列表長度 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)列表長度,如果等于,就確認(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ù)和列表長度比較,
b. 如果中間列表等于異常次數(shù),說明循環(huán)到了最后的列表,退出整個(gè)循環(huán)
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
基于Python實(shí)現(xiàn)一個(gè)AI物體識別
計(jì)算機(jī)視覺是其中的一大領(lǐng)域?,應(yīng)用場景也比較多,這篇文章主要為大家詳細(xì)介紹了如何基于Python實(shí)現(xiàn)一個(gè)AI物體識別功能,需要的小伙伴可以了解下2024-11-11Python中使用jpype調(diào)用Jar包中的實(shí)現(xiàn)方法
這篇文章主要介紹了Python中使用jpype調(diào)用Jar包中的實(shí)現(xiàn)方法,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-12-12Python調(diào)用百度AI實(shí)現(xiàn)圖片上文字識別功能實(shí)例
百度AI功能還是很強(qiáng)大的,百度AI開放平臺真的是測試接口的天堂,免費(fèi)接口很多,當(dāng)然有量的限制,但個(gè)人使用是完全夠用的,下面這篇文章主要給大家介紹了關(guān)于Python調(diào)用百度AI實(shí)現(xiàn)圖片上文字識別功能的相關(guān)資料,需要的朋友可以參考下2021-09-09python編程進(jìn)階之異常處理用法實(shí)例分析
這篇文章主要介紹了python編程進(jìn)階之異常處理用法,結(jié)合實(shí)例形式分析了python異常捕獲、處理相關(guān)語句、使用技巧與操作注意事項(xiàng),需要的朋友可以參考下2020-02-02Python在Excel中添加數(shù)據(jù)條的代碼詳解
在Excel中添加數(shù)據(jù)條是一種數(shù)據(jù)可視化技巧,它通過條形圖的形式在單元格內(nèi)直觀展示數(shù)值的大小,尤其適合比較同一列或行中各個(gè)單元格的數(shù)值,本文將介紹如何使用Python在Excel中的指定單元格區(qū)域添加數(shù)據(jù)條,需要的朋友可以參考下2024-10-10python繪制散點(diǎn)圖并標(biāo)記序號的方法
今天小編就為大家分享一篇python繪制散點(diǎn)圖并標(biāo)記序號的方法,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-12-12Python如何查找文件夾中含有指定關(guān)鍵字的文件
這篇文章主要介紹了Python如何查找文件夾中含有指定關(guān)鍵字的文件問題,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-08-08