微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

python – Pandas drop函数在for循环中不起作用?

所有!
我对此非常困惑,因为我的生活无法弄清楚错误.
我试图浏览数据框中的所有字符串并删除那些不包含字符串’Barry Bonds’的字符串.

到目前为止,我已经设法能够通过索引删除行:

bb_db.drop(bb_db.index[1])

这是成功删除该索引处的行,但是当我将其抛入此for循环时:

for i in range(len(bb_db)):
    if 'Barry Bonds' in bb_db['player_names'][i]:
        bb_db.drop(bb_db.index[i])
        print (i)

我获得了整个数据帧,即使i变量打印出大量索引,if语句为true.

谢谢!

解决方法:

drop不会改变你当前的DataFrame,除非你要求它,inplace = True.

话虽如此,for循环几乎肯定不是最简单的方法.为什么不在列上使用str访问器进行布尔索引,即使用str.contains

bb_db[~bb_db.player_names.str.contains('Barry Bonds')]

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐