df.drop_duplicates()返回删除重复行(或者列)的DataFrame
drop_duplicates()
可以删除重复的行,返回的是删除重复行后的df
DataFrame.drop_duplicates(subset=None, keep='first', inplace=False, ignore_index=False)
参数
- subset:column label or sequence of labels, optional,需要删除的列,默认是全部的列
- keep:{‘first’, ‘last’, False}, default ‘first’,确定要保留的重复项(如果有),first和last分别是第一次和最后一次,false则是删除所有的重复项
- inplace:bool, default False,是否覆盖原来的df
- ignore_index:bool, default False
返回
如果inplace=Ture,则返回删除重复项的df
官网例子
df = pd.DataFrame({ 'brand': ['Yum Yum', 'Yum Yum', 'Indomie', 'Indomie', 'Indomie'], 'style': ['cup', 'cup', 'cup', 'pack', 'pack'], 'rating': [4, 4, 3.5, 15, 5] }) df ''' brand style rating 0 Yum Yum cup 4.0 1 Yum Yum cup 4.0 2 Indomie cup 3.5 3 Indomie pack 15.0 4 Indomie pack 5.0 '''
默认情况下,它将基于所有列删除重复的行
df.drop_duplicates() ''' brand style rating 0 Yum Yum cup 4.0 2 Indomie cup 3.5 3 Indomie pack 15.0 4 Indomie pack 5.0 '''
要删除特定列上的重复项,请使用subset
df.drop_duplicates(subset=['brand']) ''' brand style rating 0 Yum Yum cup 4.0 2 Indomie cup 3.5 '''
要删除重复项并保持最后一次出现,请使用keep
df.drop_duplicates(subset=['brand', 'style'], keep='last') ''' brand style rating 1 Yum Yum cup 4.0 2 Indomie cup 3.5 4 Indomie pack 5.0 '''
===============20210430补充删除重复列============================
原来数据
import pandas as pd df1 = pd.DataFrame({'name':['张三','李四','王五','张三'],'age':[18,19,20,18]}) df2 = pd.DataFrame({'name':['张三','李四','王五','张三'],'id':[300,260,280,300]}) df3 = pd.concat([df1,df2],axis=1) #concat无how
输出df1,df2,df3
删除重复行
df3.drop_duplicates()
删除重复列
df3.T.drop_duplicates().T
总结:其实还是使用df.drop_duplicates(),只不过是转置后再去重再转置
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· winform 绘制太阳,地球,月球 运作规律
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人