python 字符串 删除重复的数据

比如:
str1 = [1, 2, 3, 4, 5]
str2 = [3, 5, 7, 9, 11]

我只想保留str2中的7, 9, 11
我的写法是:
for s in str2:
if s in str1:
str2.remove(s)
但是当数据量比较大时,这样的效率非常低,有没有什么好的方法。

可以改变下思路,减少循环次数:list转为set,然后&与下找到相同值,接着再和str2循环in的remove掉;或者set后直接减

如果实在太多(超过1w个字符)另外一个思路是用线程,即对两个list切片,然后多线程处理.
温馨提示:答案为网友推荐,仅供参考
第1个回答  推荐于2018-04-12
str3 = list(set(str2) - set(str1))本回答被提问者和网友采纳
相似回答