python 多重列表去重_python中list可以嵌套吗

973b0b548b86225d8d7af33031617b1d.png

python中的列表是可以嵌套的。将嵌套的list遍历并输出是很常见的需求。以下通过两种方法达到目的def nested_list(list_raw,result):

for item in list_raw:

if isinstance(item, list):

nested_list(item,result)

else:

result.append(item)

return  result

def flatten_list(nested):

if isinstance(nested, list):

for sublist in nested:

for item in flatten_list(sublist):

yield item

else:

yield nested

def main():

list_raw = ["a",["b","c",["d"]]]

result = []

print "nested_list is:  ",nested_list(list_raw,result)

print "flatten_list is: ",list(flatten_list(list_raw))

main()

让代码run起来,输出为:nested_list is:   ['a', 'b', 'c', 'd']

flatten_list is:  ['a', 'b', 'c', 'd']

nested_list方法采用递归的方式,如果item是list类型,继续递归调用自身。如果不是,将item加入结果列表中即可。

flatten_list方法则是采用生成器的方式,本质上也是递归的思路。

推荐学习《python教程》

2.两层嵌套list去重

list里面套了一层list,需要去重,并在生成一个去重的list。请看代码:def dup_remove_set(list_raw):

result = set()

for sublist in list_raw:

item = set(sublist)

result = result.union(item)

return list(result)

def main():

list_dup = [[1,2,3],[1,2,4,5],[5,6,7]]

print dup_remove_set(list_dup)

让代码run起来:[1, 2, 3, 4, 5, 6, 7]

基本思路:将每一个子list转为set,然后求并集,即可。

3.多重嵌套去重def dup_remove(list_raw,result):

for item in list_raw:

if isinstance(item, list):

dup_remove(item,result)

else:

result.add(item)

return  list(result)

def main():

list_raw = ["a",["b","c",["d","a","b"]]]

result = set()

print "dup_remove is:  ",dup_remove(list_raw,result)

让代码run起来:dup_remove is:   ['a', 'c', 'b', 'd']

基本思路与之前遍历嵌套list的思路差不多,唯一的区别就是之前result是一个list,而要去重的话用result是一个set,保证最后的结果为去重的结果。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值