파이썬은 하나 다 계층리스트 목록에 해결

가 다중 목록 [1, 2, 3, 4, [5, 6, [7,8], [ 'A', 'B'는, [2, 4], 하나의리스트로 분할

내장 된 방법을 사용

결과 및 다른 원래의 목록 순서

def split(li):
    pop_index_list = []  # 用来存储需要删除元素的索引
    for ele in li:
        if isinstance(ele, list):
            pop_index_list.insert(0, li.index(ele))
            li.extend(ele)

    for i in pop_index_list:
        li.pop(i)

   
li = [1, 2, 3, 4, [5, 6, [7, 8]], ['a', 'b', [2, 4]]]
split(li)
print(li)
# 结果 [1, 2, 3, 4, 5, 6, 'a', 'b', 7, 8, 2, 4]

원래 목록의 순서를 변경하지 마십시오

def split(li:list):
    for parent_i, parent_ele in enumerate(li):
        if isinstance(parent_ele, list):
            li.remove(parent_ele)
            for sub_i, sub_ele in enumerate(parent_ele):
                li.insert(parent_i+sub_i, sub_ele)
  
li = [1, 2, 3, 4, [5, 6, [7, 8]], ['a', 'b', [2, 4]]]
split(li)
print(li)        
# 结果:[1, 2, 3, 4, 5, 6, 7, 8, 'a', 'b', 2, 4]

재귀

def split(li:list, new_list=[]):
    for ele in li:
        if isinstance(ele, list):
            split(ele)
        else:
            new_list.append(ele)
    return new_list
li = [1, 2, 3, 4, [5, 6, [7, 8]], ['a', 'b', [2, 4]]]
print(split(li))
# 结果:[1, 2, 3, 4, 5, 6, 7, 8, 'a', 'b', 2, 4]

추천

출처www.cnblogs.com/ywsun/p/11402426.html