如何在循环中实现每次都在列表中最开始的元素查找。
如何在循环中实现每次都在列表中最开始的元素查找。例如:['高霞', '王鹏宇', '王鹏宇', '张丽丽', '李富贵', '邓强', '王鹏宇', '高晓丽', '李辉', '邓强', '李富贵', '刘有三', '邓强', '刘有三']中,使用for item in list ,每循环完一次,让item重新回到list位置重新开始查找。
本人小白,谢谢大神不吝赐教! 同一个循环,每一次都从开头查找,你考虑过一个问题没有,什么时候结束循环,你要的不会是死循环吧? 在外层用for或者while再写一层循环 本帖最后由 applekiller 于 2022-11-30 21:31 编辑
jackz007 发表于 2022-11-30 20:18
同一个循环,每一次都从开头查找,你考虑过一个问题没有,什么时候结束循环,你要的不会是死循环 ...
正如同我给的列表,列表中的名字有重复。我想最后的结果是列表中保留名字不重复。用list与list 中的item比较,如果重名,则把list中list中剔除,然后循环,直至list中留下不重复的名字。不会存在死循环吧。大神请赐教! 循环套循环即可 本帖最后由 柿子饼同学 于 2022-11-30 21:43 编辑
applekiller 发表于 2022-11-30 21:28
正如同我给的列表,列表中的名字有重复。我想最后的结果是列表中保留名字不重复。用list与list...
names = ['高霞', '王鹏宇', '王鹏宇', '张丽丽', '李富贵', '邓强', '王鹏宇', '高晓丽', '李辉', '邓强', '李富贵', '刘有三', '邓强', '刘有三']
print(list(set(names)))
没必要循环 , 直接用集合的性质即可 applekiller 发表于 2022-11-30 21:28
正如同我给的列表,列表中的名字有重复。我想最后的结果是列表中保留名字不重复。用list与list...
那你需要找一个临时变量来存储,例如这里通过 l[:] 切片方法将列表拷贝了一份赋值给 t,这样在循环过程中去掉原列表的元素也就不会影响到后续循环
参考代码:
l = ['高霞', '王鹏宇', '王鹏宇', '张丽丽', '李富贵', '邓强', '王鹏宇', '高晓丽', '李辉', '邓强', '李富贵', '刘有三', '邓强', '刘有三']
t = l[:]
for i in range(len(t)):
for j in t:
if t == j:
l.remove(t)
break
print(l)
另外这样去重可以直接使用 Python 内置方法:集合 Set 来去重,方便快捷
页:
[1]