【发布时间】:2017-01-13 09:01:16
【问题描述】:
这真的很奇怪。我尝试了几种方法从 pandas 数据框中删除缺少数据的行,但它们似乎都不起作用。 这是代码(我只是取消注释使用的一种方法 - 但这是我在不同修改中使用的三种方法 - 这是最新的):
import pandas as pd
Test = pd.DataFrame({'A':[1,2,3,4,5],'B':[1,2,'NaN',4,5],'C':[1,2,3,'NaT',5]})
print(Test)
#Test = Test.ix[Test.C.notnull()]
#Test = Test.dropna()
Test = Test[~Test[Test.columns.values].isnull()]
print "And now"
print(Test)
但在所有情况下,我得到的只是:
A B C
0 1 1 1
1 2 2 2
2 3 NaN 3
3 4 4 NaT
4 5 5 5
And now
A B C
0 1 1 1
1 2 2 2
2 3 NaN 3
3 4 4 NaT
4 5 5 5
我犯了什么错误吗?或者是什么问题?理想情况下,我想得到这个:
A B C
0 1 1 1
1 2 2 2
4 5 5 5
【问题讨论】:
-
你真的有字符串
NaN和NaT而不是np.nan和np.datetime64('NaN')- 因为.dropna()可以在后面正常工作... -
字符串或 np.nan 没有任何区别:(