Pandas知识点-drop和drop_duplicates最全总结

drop()参数和用法介绍

drop(labels=None, axis=0, index=None, columns=None, level=None, inplace=False, errors=‘raise’):

  • labels: 指定要删除的行索引或列名,参数传入方式为字符串或list-like。如果指定的是列名,要配合将axis参数设置为1或columns。
  • axis: 设置删除行还是删除列,0或index表示删除行,1或columns表示删除列,默认值为0。
  • index: 设置要删除的行,相当于设置labels且axis为0或index。
  • columns: 设置要删除的列,相当于设置labels且axis为1或columns。
  • level: 如果索引是多重索引,指定按多重索引中的哪个等级的索引删除,可以传入多重索引的下标或名称。
  • inplace: 设置是否在DataFrame本身删除数据,默认为False,在DataFrame的副本里删除数据,返回删除数据后的DataFrame。如果设置为True,则在调用drop()的DataFrame本身执行删除,返回值为None。
  • errors: 设置是否抛出错误,可以设置的值有{‘ignore’, ‘raise’},默认raise,表示抛出错误。ignore表示忽略错误,跳过传入的错误索引名或列名,正确的索引名或列名不受影响,正常执行删除。

drop()基本使用

# coding=utf-8
import pandas as pd


df1 = pd.DataFrame(
    {'A': ['a0', 'a1', 'a2'], 'B': ['b0', 'b1', 'b2'], 'C': ['c0', 'c1', 'c2']},
    index=['one', 'two', 'three']
)
print(df1)

Output:

A   B   C
one    a0  b0  c0
two    a1  b1  c1
three  a2  b2  c2

先创建一个DataFrame,如df1。

print('-'*20, '\n', df1.drop(labels='A', axis=1), sep='')

Output:

--------------------
        B   C
one    b0  c0
two    b1  c1
three  b2  c2

使用labels和axis参数配合删除列,如果需要删除多列,用列表给labels传参。

print('-'*20, '\n', df1.drop(index='one'), sep='')
print('-'*20, '\n', df1.drop(columns='A'), sep='')

Output:

--------------------
        A   B   C
two    a1  b1  c1
three  a2  b2  c2
--------------------
        B   C
one    b0  c0
two    b1  c1
three  b2  c2

使用index和columns可以分别删除行和列,多行多列用列表传入。也可以同时设置index和columns,同时删除行和列。

index和columns中已经隐含了axis的信息,因此不用设置axis。

df1.drop(index='one', inplace=True)
df1.drop(columns='A', inplace=True)
print('-'*20, '\n', df1, sep='')

Output:

--------------------
        B   C
two    b1  c1
three  b2  c2

inplace参数设置为True,在DataFrame本身执行行列删除操作,此时返回值为None。

print('-'*20, '\n', df1.drop(columns=['C', 'D'], errors='ignore'), sep='')

Output:

--------------------
        B
two    b1
three  b2

errors参数设置为ignore,可以忽略错误。如df1中没有D列,上面的代码不会报错,会忽略传入的D,正常删除C列。

drop()多重索引使用

df2 = pd.DataFrame(
    {'A': ['a0', 'a1', 'a2'], 'B': ['b0', 'b1', 'b2'], 'C': ['c0', 'c1', 'c2']},
    index=[['one', 'two', 'three'], [1, 2, 3]]
)
print(df2)

Output:

A   B   C
one   1  a0  b0  c0
two   2  a1  b1  c1
three 3  a2  b2  c2

新创建一个DataFrame,如df2。

print('-'*20, '\n', df2.drop(labels='two', level=0), sep='')
print('-'*20, '\n', df2.drop(labels=2, level=1), sep='')

Output:

--------------------
          A   B   C
one   1  a0  b0  c0
three 3  a2  b2  c2
--------------------
          A   B   C
one   1  a0  b0  c0
three 3  a2  b2  c2

level参数用于指定多重索引中按哪一级索引删除。如删除上面df2中的第二行,多重索引为[‘two’, 2],指定level为0时,删除索引’two’,指定level为1时,删除索引2,结果相同。

drop_duplicates()参数和用法介绍

drop_duplicates(subset=None, keep=‘first’, inplace=False, ignore_index=False):

  • subset: 设置根据列的子集来判断重复值,默认根据DataFrame的所有列来判断重复值,即所有列的数据都相同时,才算重复值。如果指定了子集,则只要子集的这些列的数据都相同,就算重复值。
  • keep: 设置保留重复值中的哪一个,可以设置的值有{‘first’, ‘last’, False},默认first,如果有重复值,则保留第一个。设置为last,则保留重复值中的最后一个。设置为False,则删除所有的重复值,一个也不保留。
  • inplace: 同drop()。
  • ignore_index: 设置是否忽略行索引,默认False,去重后的结果的行索引保持原索引不变。如果设置为True,则结果的行索引被重置为0开始的自然数。

drop_duplicates()基本使用

df3 = pd.DataFrame(
    {'A': ['a0', 'a1', 'a1', 'a2', 'a2'],
     'B': ['b0', 'b1', 'b1', 'b2', 'b2'],
     'C': ['c0', 'c1', 'c1', 'c2', 'c3']},
    index=['one', 'two', 'three', 'four', 'five']
)
print(df3)

Output:

A   B   C
one    a0  b0  c0
two    a1  b1  c1
three  a1  b1  c1
four   a2  b2  c2
five   a2  b2  c3

新创建一个DataFrame,如df3。

print('-'*20, '\n', df3.drop_duplicates(), sep='')

Output:

--------------------
       A   B   C
one   a0  b0  c0
two   a1  b1  c1
four  a2  b2  c2
five  a2  b2  c3

默认删除重复值的方式,所有列的数据都相同时判定为重复,保留第一个。

print('-'*20, '\n', df3.drop_duplicates(subset=['A', 'B']), sep='')

Output:

--------------------
       A   B   C
one   a0  b0  c0
two   a1  b1  c1
four  a2  b2  c2

设置subset参数后,只要subset中的列数据相同,就判定为重复值。

print('-'*20, '\n', df3.drop_duplicates(keep='last'), sep='')
print('-'*20, '\n', df3.drop_duplicates(keep=False), sep='')

Output:

--------------------
        A   B   C
one    a0  b0  c0
three  a1  b1  c1
four   a2  b2  c2
five   a2  b2  c3
--------------------
       A   B   C
one   a0  b0  c0
four  a2  b2  c2
five  a2  b2  c3

keep参数设置为last,保留重复值中的最后一个。设置为False,则全部都删除,一个也不保留。

print('-'*20, '\n', df3.drop_duplicates(ignore_index=True), sep='')

Output:

--------------------
    A   B   C
0  a0  b0  c0
1  a1  b1  c1
2  a2  b2  c2
3  a2  b2  c3

ignore_index设置为True后,结果的行索引被重置为0开始的自然数。

参考文档:
[1] pandas中文网:https://www.pypandas.cn/docs/