pandas 某一列中如果出现重复数据,将当前行和出现重复数据的行进行比较
时间: 2024-05-06 11:19:11 浏览: 79
可以通过 pandas 的 `duplicated()` 和 `groupby()` 方法来实现。
首先,使用 `duplicated()` 方法检查某一列是否有重复数据。例如,我们要查找 DataFrame `df` 中列名为 `col1` 的列是否有重复数据:
```python
duplicates = df['col1'].duplicated()
```
`duplicates` 是一个布尔型的 Series,其中 `True` 表示该行数据在 `col1` 中有重复数据。
接下来,使用 `groupby()` 方法按照 `col1` 进行分组,然后使用 `transform()` 方法将分组后的数据与原始数据进行比较。例如,我们要将重复数据与其对应行进行比较,并将结果保存在新的列 `compare_col` 中:
```python
compare_col = df.groupby('col1')['col2'].transform(lambda x: x == x[duplicates])
df['compare_col'] = compare_col
```
上述代码中,`groupby('col1')['col2']` 表示将 DataFrame 按照 `col1` 进行分组,并取出每个分组中的 `col2` 列。`transform()` 方法将每个分组中的 `col2` 列与重复数据进行比较,然后返回一个布尔型的 Series,表示比较结果。最后,将该 Series 赋值给新的列 `compare_col`。
这样,就可以将出现重复数据的行和当前行进行比较,并将结果保存在新的列中了。
阅读全文