python中从列表中用for循环删除(remove方法)停用词特别慢,有快一点的方法吗? 5
5个回答
展开全部
python中最好不要在list遍历中使用list.remove方法:
remove 仅仅 删除一个值的首次出现。
如果在 list 中没有找到值,程序会抛出一个异常
- 最后,你遍历自己时候对自己的内容进行删除操作,效率显然不高,还容易出现各种难debug的问题
建议使用新的list存储要保留的内容,然后返回这个新list。比如
a_list = [1,2,3,4,5]
needs_to_be_removed = [3,4,5]
result = []
for v in a_list:
if v not in needs_to_be_removed:
result.append(v)
print result
展开全部
循环删除,必须用循环语句,而循环语句就那么几个!!
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
那就别用列表啦~换dict吧
如果非要用,就排下序,再用二分查找,for肯定很慢啦
如果非要用,就排下序,再用二分查找,for肯定很慢啦
追问
慢的原因主要是因为for遍历吗?不是因为remove方法?
追答
我不清楚remove怎么写的,应该不会很慢,但是遍历确实很慢
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
为什么不用remove或是pop?
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
可以贴一下循环的代码么,看哪里能改良
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询