我有一个pandas
带有列的数据框uniqueid
。我想根据此列从数据框中删除所有重复项,以便所有剩余的观察结果都是唯一的。
问问题
14756 次
2 回答
12
还有drop_duplicates()
适用于任何数据框的方法(此处的文档)。您可以将要删除的特定列作为参数传递。
df.drop_duplicates(subset='uniqueid', inplace=True)
于 2013-11-01T04:13:27.793 回答
10
由于我们只关心uniqueid
(A
在我的示例中)是否重复,因此选择它并调用duplicated
该系列。然后使用~
翻转布尔值。
In [90]: df = pd.DataFrame({'A': ['a', 'b', 'b', 'c'], 'B': [1, 2, 3, 4]})
In [91]: df
Out[91]:
A B
0 a 1
1 b 2
2 b 3
3 c 4
In [92]: df['A'].duplicated()
Out[92]:
0 False
1 False
2 True
3 False
Name: A, dtype: bool
In [93]: df.loc[~df['A'].duplicated()]
Out[93]:
A B
0 a 1
1 b 2
3 c 4
于 2013-11-01T01:35:05.053 回答