首頁常見問題正文

Pandas怎樣實現(xiàn)單層索引訪問數(shù)據(jù)?

更新時間:2023-11-03 來源:黑馬程序員 瀏覽量:

pandas中提供了多種使用單層索引訪問Series類對象和DataFrame類對象的方式,包括[]、loe、iloc、at和iat,關于這幾種方式的介紹如下。

1.使用[]訪問數(shù)據(jù)

pandas中使用[]訪問數(shù)據(jù)的方式與訪問數(shù)組元素的方式類似,其使用方式如下。

變量{索引}

需要說明的是,若變量是一個Series類對象,則會獲取索引對應的單個數(shù)據(jù);若變量是一個DataFrame類對象,它在使用“[索引J”訪問數(shù)據(jù)時會將索引視為列索引,獲取該索引對應的一列數(shù)據(jù)。

下面創(chuàng)建一個Series類對象ser,使用“變量[索引]”訪問該對象的單個數(shù)據(jù),代碼如下。

In []:   inport pandas as pd
         ser = pd.Series(['A', 'B','C','D'],
                     index=('one','two','three',*four'])
         print(ser)
         one      A
         two      B
         three    C
         four     D
         dtype: object
In []:   # 訪問素引為'one'的數(shù)據(jù)
         print(ser['one'])
         A

下面創(chuàng)建一個DataFrame類對象df,使用“變量[索引]”訪問該對象的一列數(shù)據(jù),代碼如下。

In []:  df = pd.DataF'rame([[0, 2, 3], [0, 4, 1], [10, 20, 30]],
                        index=|4, 5, 6], columns=['A', 'B', 'C'])
        print(df)
            A B  C
         4  0  2  3
         5  0  4  3
         6 10 20 30
In  []:  # 訪問列索引為'A'的數(shù)據(jù)
         print(df['A'])
         4    O
         5    0
         6   10
         Name: A, dtype: int64

2.使用loc和iloc訪問數(shù)據(jù)

pandas 中也可以使用loc和iloc訪問數(shù)據(jù),其使用方式如下。

變量.loc[索引]
變量.iloc[索引]

以上方式中,“l(fā)od[索引]”中的索引必須為自定義的標簽索引,而“ilocf[索引]”中的索引必須為自動生成的整數(shù)索引。需要說明的是,若變量是一個DataFrame類對象,它在使用“l(fā)oc[索引]”或“iloc[索引]”訪問數(shù)據(jù)時會將索引視為行索引,獲取該索引對應的一行數(shù)據(jù)。

接下來,分別使用loc和iloc訪問ser對象中標簽索引為'two'與整數(shù)索引為2的數(shù)據(jù),代碼如下。

In []:   #  訪問標簽索引為'two'的數(shù)據(jù)
         print(ser.loc('two'))
         B
In []:   訪問整數(shù)索引為2的數(shù)據(jù)
         print(ser.1loc[2))
         C

使用loc和iloc訪問df對象中標簽索引為4和整數(shù)索引為1的數(shù)據(jù),代碼如下。

In []:    # 訪問標簽索引為4的數(shù)據(jù)
          print(df.loc(4])
          A   0
          B   2
          C   3
          Name: 4, dtype: int64
In []:    # 訪問整數(shù)索引為1的數(shù)據(jù)
          print(df.iloc[1])
          A    0
          B    4
          C    1
          Name: 5, dtype: int64

3.使用at和iat訪問數(shù)據(jù)

pandas 中還可以使用at和iat 訪問數(shù)據(jù)。與前兩種方式相比,這種方式可以訪問DataFrame類對象中的單個數(shù)據(jù)。以DataFrame類對象為例,使用at和iat 訪問數(shù)據(jù)的基本方式如下。

變量.at[行素引,列索引1
變量,iat[行素引,列索引]

以上方式中,“at[行索引,列索引]”中的索引必須為自定義的標簽索引,“iat[行索引,列索引]”中的索引必須為自動生成的整數(shù)索引。

接下來,使用at訪問d對象中行標簽索引為5、列標簽索引為B'的數(shù)據(jù),代碼如下。

In []:  # 訪問行標簽索引為5、列標簽索引為'8'的數(shù)據(jù)
        print(df.at[5,'B'])
        4


分享到:
在線咨詢 我要報名
和我們在線交談!