通过整数索引选择一行熊猫系列/数据框

发布于 2021-01-29 15:00:14

我很好奇,为什么df[2]不支持,而df.ix[2]df[2:3]这两个工作。

In [26]: df.ix[2]
Out[26]: 
A    1.027680
B    1.514210
C   -1.466963
D   -0.162339
Name: 2000-01-03 00:00:00

In [27]: df[2:3]
Out[27]: 
                  A        B         C         D
2000-01-03  1.02768  1.51421 -1.466963 -0.162339

我希望df[2]df[2:3]与Python索引约定一致的方式进行工作。有设计上的原因不支持按单个整数索引行吗?

关注者
0
被浏览
88
1 个回答
  • 面试哥
    面试哥 2021-01-29
    为面试而生,有面试问题,就找面试哥。

    回显@HYRY,请参阅0.11中的新文档

    http://pandas.pydata.org/pandas-
    docs/stable/indexing.html

    在这里,我们有了新的运算符,.iloc以显式支持仅整数索引,并且.loc显式仅支持标签索引

    例如,想象这种情况

    In [1]: df = pd.DataFrame(np.random.rand(5,2),index=range(0,10,2),columns=list('AB'))
    
    In [2]: df
    Out[2]: 
              A         B
    0  1.068932 -0.794307
    2 -0.470056  1.192211
    4 -0.284561  0.756029
    6  1.037563 -0.267820
    8 -0.538478 -0.800654
    
    In [5]: df.iloc[[2]]
    Out[5]: 
              A         B
    4 -0.284561  0.756029
    
    In [6]: df.loc[[2]]
    Out[6]: 
              A         B
    2 -0.470056  1.192211
    

    [] 仅对行进行切片(按标签位置)



知识点
面圈网VIP题库

面圈网VIP题库全新上线,海量真题题库资源。 90大类考试,超10万份考试真题开放下载啦

去下载看看