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']})
dfname 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?? ??? ?maleindex、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é)果返回賦值給原變量,無需再次將結(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 13errors:{‘ignore’, ‘raise’}, default ‘ignore’
發(fā)生錯(cuò)誤的處理方式,ignore為忽略,raise為報(bào)錯(cuò)。比如改名字是,如果傳入的參數(shù)中包含索引列沒有的值,就會(huì)報(bào)錯(cuò),ignore或者raise來決定錯(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將多個(gè)文本文件合并為一個(gè)文本的代碼(便于搜索)
源代碼目錄一般很詳細(xì),每個(gè)代碼文件都不長(zhǎng),一般只占幾十行而已。在跟著書籍學(xué)習(xí)的過程中,可以打開源代碼運(yùn)行之后查看效果,或者適當(dāng)修改看看變化,這都是很好的掌握技術(shù)的好辦法。2011-03-03
Python實(shí)現(xiàn)不規(guī)則圖形填充的思路
這篇文章主要介紹了Python實(shí)現(xiàn)不規(guī)則圖形填充的思路,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-02-02
一文教會(huì)你使用Python來下一場(chǎng)雪
這篇文章主要給大家介紹了關(guān)于使用Python來下一場(chǎng)雪的相關(guān)資料,文章描述了大雪緩緩下落的場(chǎng)景,并提供了完整的代碼示例,對(duì)大家學(xué)習(xí)或者使用python具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2024-11-11
python解決Fedora解壓zip時(shí)中文亂碼的方法
這篇文章給大家介紹了如何利用python解決Fedora解壓zip時(shí)中文亂碼的方法,對(duì)大家具有一定參考借鑒價(jià)值,有需要的朋友們可以參考學(xué)習(xí),下面來一起看看吧。2016-09-09
導(dǎo)入tensorflow:ImportError: libcublas.so.9.0 報(bào)錯(cuò)
這篇文章主要介紹了導(dǎo)入tensorflow:ImportError: libcublas.so.9.0 報(bào)錯(cuò),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-01-01
python 實(shí)現(xiàn)簡(jiǎn)易的記事本
這篇文章主要介紹了python 實(shí)現(xiàn)簡(jiǎn)易的記事本的示例代碼,幫助大家更好的理解和學(xué)習(xí)python,感興趣的朋友可以了解下2020-11-11
Python初學(xué)者需要注意的事項(xiàng)小結(jié)(python2與python3)
這篇文章主要介紹了Python初學(xué)者需要注意的事項(xiàng)小結(jié),包括了python2與python3的一些區(qū)別,需要的朋友可以參考下2018-09-09

