我有一个包含几千行的数据框。其中一列称为 C
,我们有兴趣了解数字 7 是否出现在该列中。
我尝试过:print(7 in df["C"])
,它返回True
,但是print(df.index[df["C] "] == 7].tolist())
返回 []
。
这是怎么回事?我缺少in
的哪些方面?
最佳答案
因为in
检查索引值,所以是gotcha :
df = pd.DataFrame({
'A': ['a','a','a','a','b','b','b','c','d'],
'C': list(range(10, 19))
})
print (df)
A C
0 a 10
1 a 11
2 a 12
3 a 13
4 b 14
5 b 15
6 b 16
7 c 17
8 d 18
print(7 in df["C"])
True
print(10 in df["C"])
False
并且在C
列中没有值7
,因此返回空列表:
print(df.index[df["C"] == 7].tolist())
关于python - Pandas 在 df ["C"中说 7 ] 但实际上要求 7 的索引返回空列表 - 为什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48558514/