欢迎这位怪蜀黍来到《Python机器学习(八十七)Pandas 去除重复 - 大码王 - 博客园》

关闭页面特效

去除重复数据是一项常见操作,Pandas中,可以使用drop_duplicates方法。

电影数据集没有重复的行,我们来制造一些重复行。

temp_df = movies_df.append(movies_df)

temp_df.shape

输出

(2000, 11)

append()将返回一个副本,不影响原始数据DataFrame。使用.shape属性查看形状,可以看到数据增加了一倍。

接下来删除重复数据:

temp_df2 = temp_df.drop_duplicates()

temp_df2.shape

输出

(1000, 11)

append()一样,此处drop_duplicate()方法也将返回副本。

如果想直接在原数据上修改,可以指定参数:inplace=True,Pandas的许多方法都可使用inplace参数。

temp_df.drop_duplicates(inplace=True)

temp_df被直接修改,里面的重复项被去除。

drop_duplicate()的另一个重要参数是keep,它有三个可能的选项:

first: (默认)删除重复项,但保留的是首次出现的项。
last: 删除重复项,但保留的是最后出现的项。
False: 删除重复项,不保留任何重复项。

前面的示例中没有定义keep参数,所以默认值为first。这意味着如果两行是相同的,Pandas将删除第二行保留第一行。使用last效果相反: 第一行被删除保留第二行。False值会删除所有的重复项,如果两行是相同的,这两行都将被删除。

temp_df = movies_df.append(movies_df)  # make a new copy

temp_df.drop_duplicates(inplace=True, keep=False)

temp_df.shape

输出

(0, 11)

因为所有行都是重复的,所以keep=False将删除所有行。

 posted on   大码王  阅读(2140)  评论(0编辑  收藏  举报
编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具

成都

复制代码

喜欢请打赏

扫描二维码打赏

了解更多

点击右上角即可分享
微信分享提示