23

我有一个数据框。然后我有一个逻辑条件,我使用它通过删除一些行来创建另一个数据框。但是,新数据框会跳过已删除行的索引。我怎样才能让它在不跳过的情况下按顺序重新索引?这是一个示例编码以澄清

import pandas as pd
import numpy as np

jjarray = np.array(range(5))
eq2 = jjarray == 2
neq2 = np.logical_not(eq2)

jjdf = pd.DataFrame(jjarray)
jjdfno2 = jjdf[neq2]

jjdfno2

出去:

  0
0 0
1 1
3 3
4 4

我希望它看起来像这样:

  0
0 0
1 1
2 3
3 4

谢谢。

4

1 回答 1

40

一种方法是使用reset_index

>>> df = pd.DataFrame(range(5))
>>> eq2 = df[0] == 2
>>> df_no_2 = df[~eq2]
>>> df_no_2
   0
0  0
1  1
3  3
4  4
>>> df_no_2.reset_index(drop=True)
   0
0  0
1  1
2  3
3  4
于 2013-03-21T20:41:07.893 回答