pandas中df.rename()的具體使用
df.rename()用于更改行列的標(biāo)簽,即行列的索引。可以傳入一個(gè)字典或者一個(gè)函數(shù)。在數(shù)據(jù)預(yù)處理中,比較常用。
官方文檔:
DataFrame.rename(self, mapper=None, index=None, columns=None, axis=None, copy=True, inplace=False, level=None, errors=‘ignore’)
參數(shù)解釋:
創(chuàng)建實(shí)例
import pandas as pd df = pd.DataFrame({'name':['zhao','qian','sun','wang'],'mark':[150,122,155,132],'gender':['female','female','male','male']}) df
name mark gender
0 zhao 150 female
1 qian 122 female
2 zhou 155 male
3 wang 132 male
mapper:dict or function
映射關(guān)系,可以是字典,也可以是一個(gè)函數(shù)。
df.rename({0:111}) ?? ?name?? ?mark?? ?gender 111?? ?zhao?? ?150?? ??? ?female #行索引從0變?yōu)?11 1?? ?qian?? ?122?? ??? ?female 2?? ?zhou?? ?155?? ??? ?male 3?? ?wang?? ?132?? ??? ?male df.rename(lambda x: x+11) #參數(shù)也可以是函數(shù),索引都加了11 ?? ?name?? ?mark?? ?gender 11?? ?zhao?? ?150?? ??? ?female 12?? ?qian?? ?122?? ??? ?female 13?? ?zhou?? ?155?? ??? ?male 14?? ?wang?? ?132?? ??? ?male
index、columns、axis:
這3個(gè)參數(shù)作用類似,dataframe中有行和列兩個(gè)方向,在改名時(shí),需要指明改名的是行還是列(默認(rèn)是行),使用df.rename(index = mapper)或者df.rename(columns=mapper)的形式,和df.rename(mapper,axis=0 or 1)的效果是一樣的
df.rename(lambda x: x+'11',axis=1) ?? ?name11?? ?mark11?? ?gender11 ?#列索引都加了11,name變?yōu)閚ame11 0?? ?zhao?? ?150?? ??? ?female 1?? ?qian?? ?122?? ??? ?female 2?? ?zhou?? ?155?? ??? ?male 3?? ?wang?? ?132?? ??? ?male df.rename(columns=lambda x: x+'11')#等價(jià)于上面,寫法更簡(jiǎn)潔直觀 ?? ?name11?? ?mark11?? ?gender11 0?? ?zhao?? ?150?? ??? ?female 1?? ?qian?? ?122?? ??? ?female 2?? ?zhou?? ?155?? ??? ?male 3?? ?wang?? ?132?? ??? ?male
copy:bool,default = True
默認(rèn)為True,效果不清楚。。。文檔就一句話,與會(huì)復(fù)制底層數(shù)據(jù)(also copy underlying data), 等一個(gè)課代表解答一下。
inplace:bool,default False
將結(jié)果返回賦值給原變量,無(wú)需再次將結(jié)果賦值給新變量。即df.rename(inplace=True)之后,df的值發(fā)生改變(pandas中好多方法都有這個(gè)參數(shù),此處就演示了)
level int,level name,default none
針對(duì)多層索引,指定需要改名字的索引具體是哪一個(gè)。
df1 = pd.DataFrame([10,11,12,13],index=[['a','a','b','b'],[1,2,3,4],[4,3,2,1]],columns=['tt']) df1 tt #前三列都為索引 a 1 4 10 2 3 11 b 3 2 12 4 1 13 df1.rename(index={1:'dd'}) tt#索引中所有的1都變成了dd a dd 4 10 2 3 11 b 3 2 12 4 dd 13 df1.rename(index={1:'dd'},level=1) tt#只有第2列索引改為dd(從0開始計(jì)數(shù)) a dd 4 10 2 3 11 b 3 2 12 4 1 13
errors:{‘ignore’, ‘raise’}, default ‘ignore’
發(fā)生錯(cuò)誤的處理方式,ignore為忽略,raise為報(bào)錯(cuò)。比如改名字是,如果傳入的參數(shù)中包含索引列沒有的值,就會(huì)報(bào)錯(cuò),ignore或者raise來(lái)決定錯(cuò)誤的處理方式
df1 tt #前三列都為索引 a 1 4 10 2 3 11 b 3 2 12 4 1 13 df1.rename(index={11:'dd'},level=1,errors='raise') KeyError: '[11] not found in axis'#報(bào)錯(cuò),11沒在索引內(nèi)
到此這篇關(guān)于pandas中df.rename()的具體使用的文章就介紹到這了,更多相關(guān)pandas df.rename()內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- Pandas數(shù)據(jù)類型轉(zhuǎn)換df.astype()及數(shù)據(jù)類型查看df.dtypes的使用
- Pandas查詢數(shù)據(jù)df.query的使用
- Pandas中df.loc[]與df.iloc[]的用法與異同?
- Pandas缺失值填充 df.fillna()的實(shí)現(xiàn)
- Pandas索引排序 df.sort_index()的實(shí)現(xiàn)
- Pandas數(shù)據(jù)形狀df.shape的實(shí)現(xiàn)
- Pandas缺失值刪除df.dropna()的使用
- pandas || df.dropna() 缺失值刪除操作
- pandas數(shù)據(jù)選?。篸f[] df.loc[] df.iloc[] df.ix[] df.at[] df.iat[]
- pandas 強(qiáng)制類型轉(zhuǎn)換 df.astype實(shí)例
相關(guān)文章
Python字典的基本用法實(shí)例分析【創(chuàng)建、增加、獲取、修改、刪除】
這篇文章主要介紹了Python字典的基本用法,結(jié)合具體實(shí)例形式分析了Python字典的創(chuàng)建、增加、獲取、修改、刪除等基本操作技巧與注意事項(xiàng),需要的朋友可以參考下2019-03-03機(jī)器學(xué)習(xí)的框架偏向于Python的13個(gè)原因
這篇文章主要為大家詳細(xì)介紹了機(jī)器學(xué)習(xí)的框架偏向于Python的13個(gè)原因,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-12-12python神經(jīng)網(wǎng)絡(luò)TensorFlow簡(jiǎn)介常用基本操作教程
這篇文章主要介紹了python神經(jīng)網(wǎng)絡(luò)入門TensorFlow簡(jiǎn)介常用基本操作教程,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步2021-11-11Python 實(shí)現(xiàn)一個(gè)顏色色值轉(zhuǎn)換的小工具
這篇文章主要介紹了Python 實(shí)現(xiàn)一個(gè)顏色色值轉(zhuǎn)換的小工具的相關(guān)資料,需要的朋友可以參考下2016-12-12python實(shí)現(xiàn)圖像隨機(jī)裁剪的示例代碼
這篇文章主要介紹了python實(shí)現(xiàn)圖像隨機(jī)裁剪的示例代碼,幫助大家更好的理解和使用python處理圖片,感興趣的朋友可以了解下2020-12-12