Python讀取DataFrame的某行或某列的方法實(shí)現(xiàn)
行索引、列索引、loc和iloc
import pandas as pd
import numpy as np
# 準(zhǔn)備數(shù)據(jù)
df = pd.DataFrame(np.arange(12).reshape(3,4),index=list("abc"),columns=list("WXYZ"))

行索引(index):對(duì)應(yīng)最左邊那一豎列
列索引(columns):對(duì)應(yīng)最上面那一橫行
.loc[]官方釋義: Access a group of rows and columns by label(s) or a boolean array.(通過(guò)標(biāo)簽或布爾數(shù)組訪問(wèn)一組行和列) 官方鏈接
- loc使用索引來(lái)取值,基礎(chǔ)用法 df.loc[[行索引],[列索引]]
.iloc[]官方釋義: Purely integer-location based indexing for selection by position.(按位置進(jìn)行索引選擇) 官方鏈接
- iloc使用位置(從0開(kāi)始)來(lái)取值,基礎(chǔ)用法 df.iloc[[行位置],[列位置]]
一、根據(jù)列索引取某一列/多列(常用)
df['W'] # 取‘W'列,返回類型是Series df[['W']] # 取‘W'列,返回類型是DataFrame df[['W','Y']] # 取‘W'列和‘Y'列 df.loc[:,'W':'Y'] # 取‘W'列到‘Y'列
二、根據(jù)行索引取某一行/多行
df.loc['a'] # 取‘a(chǎn)'行,返回類型是Series df.loc[['a']] # 取‘a(chǎn)'行,返回類型是DataFrame df.loc[['a','c']] # 取‘a(chǎn)'行和‘c'行,也可以寫成 df.loc[['a','c'],:] df.loc['a':'c',:] # 取‘a(chǎn)'行到‘c'行
三、根據(jù)列位置取某一列/多列
df.iloc[:,1] # 取第2列(‘X'列),列號(hào)為1,返回類型是Series df.iloc[:,0:2] # 取前2列(‘W'列和‘X'列),列號(hào)為0和1 df.iloc[:,0:-1] # 取最后一列之前的所有列
四、根據(jù)行位置取某一行/多行(常用)
df[:2] #取前2行,行號(hào)為0和1 df[1:2] #取第2行,行號(hào)為1 df.iloc[1] # 取第2行(‘b'行),行號(hào)為1,返回類型是Series,也可以寫成df.iloc[1,:]
五、取某一行某一列(常用)
df.loc[['b'],['W']] # 取‘b'行‘W'列,返回類型是DataFrame,帶著行、列索引的 df.loc['b','W'] # 取‘b'行‘W'列的值,返回類型是int,不帶行列索引 df.loc['b']['W'] # 取‘b'行‘W'列的值(從Series類型df.loc['b']中通過(guò)索引取值) df.iloc[[0],[0]] # 取第1行、第1列,返回類型是DataFrame,帶著行、列索引的 df.iloc[0,0] # 取第1行、第1列的值 df.iloc[0][0] # 取第1行、第1列的值(從Series類型df.iloc[0]中通過(guò)序號(hào)取值) df.iloc[0]['W'] # 取第1行、‘W'列的值(從Series類型df.iloc[0]中通過(guò)索引取值)
六、取多行多列
df[:2][['W','Y']] # 取前2行的‘W'列和'Y‘列 df[:2].loc[:2,'W':'Y'] # 取前2行的‘W'列到'Y‘列 df.iloc[0][['W','Y']] # 取第1行的‘W'列和'Y‘列 df.iloc[0]['W':'Y'] # 取第1行的‘W'列到'Y‘列 df.loc[["a","c"],["W","Y"]] # 取‘a(chǎn)'行和‘c'行,‘W'列和‘Y'列 df.iloc[[0,2],[1,3]] # 取1、3行,2、4列
總結(jié): 一般通過(guò)行位置來(lái)取行,通過(guò)列索引來(lái)取列,且行索引大多數(shù)情況下和行位置是相同的。
最常用的是以下幾個(gè)
# 取某一列 df['W'] # 取某一行 df.iloc[0] # 取多列 df.loc[:,'W':'Y'] # 取‘W'列到‘Y'列 df.iloc[:,0:-1] # 取最后一列之前的所有列 # 取對(duì)應(yīng)行列的值 df.iloc[0]['W'] df.loc['a','W'] # 在行索引和行位置相同的情況下的寫法就是,df.loc[0,'W']
到此這篇關(guān)于Python讀取DataFrame的某行或某列的方法實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)Python讀取DataFrame行列內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python實(shí)現(xiàn)CNN的多通道輸入實(shí)例
今天小編就為大家分享一篇Python實(shí)現(xiàn)CNN的多通道輸入實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-01-01
Python+matplotlib實(shí)現(xiàn)餅圖的繪制
Matplotlib是一個(gè)Python的2D繪圖庫(kù),它以各種硬拷貝格式和跨平臺(tái)的交互式環(huán)境生成出版質(zhì)量級(jí)別的圖形。本文將利用Matplotlib庫(kù)繪制餅圖,感興趣的可以了解一下2022-03-03
python實(shí)現(xiàn)百度文庫(kù)自動(dòng)化爬取
項(xiàng)目是合法項(xiàng)目,只是進(jìn)行數(shù)據(jù)解析而已,不能下載看不到的內(nèi)容.部分文檔在電腦端不能預(yù)覽,但是在手機(jī)端可以預(yù)覽,所有本項(xiàng)目把瀏覽器瀏覽格式改成手機(jī)端,支持Windows和Ubuntu. 本項(xiàng)目使用的是chromedriver來(lái)控制chrome來(lái)模擬人來(lái)操作來(lái)進(jìn)行文檔爬取2021-04-04
Python3 queue隊(duì)列模塊詳細(xì)介紹
queue是python中的標(biāo)準(zhǔn)庫(kù),俗稱隊(duì)列。這篇文章給大家介紹了Python3 queue隊(duì)列模塊,包括模塊中的常用方法及構(gòu)造函數(shù),需要的朋友參考下吧2018-01-01
簡(jiǎn)單了解Django ORM常用字段類型及參數(shù)配置
這篇文章主要介紹了簡(jiǎn)單了解Django ORM常用字段類型及參數(shù)配置,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-01-01
Python利用 SVM 算法實(shí)現(xiàn)識(shí)別手寫數(shù)字
支持向量機(jī) (Support Vector Machine, SVM) 是一種監(jiān)督學(xué)習(xí)技術(shù),它通過(guò)根據(jù)指定的類對(duì)訓(xùn)練數(shù)據(jù)進(jìn)行最佳分離,從而在高維空間中構(gòu)建一個(gè)或一組超平面。本文將介紹通過(guò)SVM算法實(shí)現(xiàn)手寫數(shù)字的識(shí)別,需要的可以了解一下2021-12-12
python 將列表中的字符串連接成一個(gè)長(zhǎng)路徑的方法
今天小編就為大家分享一篇python 將列表中的字符串連接成一個(gè)長(zhǎng)路徑的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-10-10

