每日一python(3):python 中对list去重的两种方法

本文介绍了两种Python列表去重的方法,一是通过遍历并检查元素是否已存在新列表中,二是利用set的自动去重特性。前者能保持元素顺序,但效率较低;后者速度快,但可能改变元素顺序。文章还提供了通过索引排序来保持set去重后顺序的技巧。

在python相关职位的面试过程中,会对列表list的去重进行考察。(注意有时会要求保证去重的顺序性

方法1:直观方法

思路:先建立一个新的空列表,通过遍历原来的列表,再利用逻辑关系not in 来去重

代码:

   #coding:utf-8
   
	ll = [1, 2, 3, 3, 4, 5, 6, 6, 6,7,8,8,9,10,10]
	new_ll = []
	for i in ll:
		if i not in new_ll:
			new_ll.append(i)
	print(new_ll)

输出:

[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]

**总结:**这样可以做出来,但是过程不够简单。但是此方法保证了列表的顺序性

方法2:利用set的自动去重功能

**思路:**将列表转化为集合再转化为列表,利用集合的自动去重功能,简单快速。缺点是:使用set方法无法保证去重后的顺序。

代码:

ll = [11,22,33,44,11,22]
ll = list(set(ll))
print(ll)

输出:

[33, 11, 44, 22]

虽然set方法不能保证去重后的顺序,但是可以通过列表中索引(index)的方法保证去重后的顺序不变,如下:

ll = [11,22,33,44,11,22]
new_ll = list(set(ll))
new_ll.sort(key=ll.index)
print(new_ll)

输出:

[11, 22, 33, 44]

总结:python的set和其他语言类似,是一个无序不重复元素集

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值