我需要删除熊猫数据框的前三行。
我知道df.ix[:-1]
会删除最后一行,但我不知道如何删除前 n 行。
我认为更明确的方法是使用 drop。
语法是:
df.drop(label)
正如@tim 和@ChaimG 所指出的,这可以就地完成:
df.drop(label, inplace=True)
一种实现方式可能是:
df.drop(df.index[:3], inplace=True)
另一个“就地”使用:
df.drop(df.head(3).index, inplace=True)
df = df.iloc[n:]
n 删除前 n 行。
一种简单的方法是使用 tail(-n) 删除前 n 行
df=df.tail(-3)
df.drop(df.index[[0,2]])
Pandas 使用从零开始的编号,因此 0 是第一行,1 是第二行,2 是第三行。
您可以使用 python 切片,但请注意它不是就地的。
In [15]: import pandas as pd
In [16]: import numpy as np
In [17]: df = pd.DataFrame(np.random.random((5,2)))
In [18]: df
Out[18]:
0 1
0 0.294077 0.229471
1 0.949007 0.790340
2 0.039961 0.720277
3 0.401468 0.803777
4 0.539951 0.763267
In [19]: df[3:]
Out[19]:
0 1
3 0.401468 0.803777
4 0.539951 0.763267
inp0= pd.read_csv("bank_marketing_updated_v1.csv",skiprows=2)
或者如果你想在现有的数据框中做
只需执行以下命令
有一种简单的方法可以通过drop命令来实现。
df = df.drop(3)