網(wǎng)站首頁 編程語言 正文
如果要交換(轉(zhuǎn)置)pandas.DataFrame的行和列,使用T屬性或transpose()方法。
這兩種方法都不會(huì)保留原始對象不變,也不會(huì)返回交換了行和列(轉(zhuǎn)置)的新對象。請注意,根據(jù)每一列的數(shù)據(jù)類型dtype,將生成視圖而不是副本,并且更改原始對象和轉(zhuǎn)置對象之一的值將更改另一個(gè)視圖。
pandas.DataFrame.T
可以使用T屬性獲得轉(zhuǎn)置的pandas.DataFrame。
import pandas as pd
df = pd.DataFrame({'X': [0, 1, 2], 'Y': [3, 4, 5]}, index=['A', 'B', 'C'])
print(df)
# ? ?X ?Y
# A ?0 ?3
# B ?1 ?4
# C ?2 ?5
print(df.T)
# ? ?A ?B ?C
# X ?0 ?1 ?2
# Y ?3 ?4 ?5
pandas.DataFrame.transpose()
transpose()方法類似。
print(df.transpose())
# A B C
# X 0 1 2
# Y 3 4 5
修改原始對象本身
沒有像inplace這樣的參數(shù)可以修改原始對象本身。如果不想創(chuàng)建新對象,只需將其分配給原始對象本身即可。
df = df.T
print(df)
# A B C
# X 0 1 2
# Y 3 4 5
當(dāng)進(jìn)行類型轉(zhuǎn)換(廣播)時(shí)
為pandas.DataFrame中的每一列設(shè)置數(shù)據(jù)類型dtype。
如果所有列都具有相同的數(shù)據(jù)類型,則即使通過T或transpose()進(jìn)行轉(zhuǎn)置,該數(shù)據(jù)類型也將保持相同。
df = pd.DataFrame({'X': [0, 1, 2], 'Y': [3, 4, 5]}, index=['A', 'B', 'C'])
print(df)
# ? ?X ?Y
# A ?0 ?3
# B ?1 ?4
# C ?2 ?5
print(df.dtypes)
# X ? ?int64
# Y ? ?int64
# dtype: object
print(df.T)
# ? ?A ?B ?C
# X ?0 ?1 ?2
# Y ?3 ?4 ?5
print(df.T.dtypes)
# A ? ?int64
# B ? ?int64
# C ? ?int64
# dtype: object
如果每一列都有不同的數(shù)據(jù)類型,則執(zhí)行類型轉(zhuǎn)換(廣播)。例如,如果作為轉(zhuǎn)置的結(jié)果生成了其中混合了整數(shù)int和浮點(diǎn)數(shù)float的列,則該列的數(shù)據(jù)類型變?yōu)閒loat。
df_mix = pd.DataFrame({'col_int': [0, 1, 2], 'col_float': [0.1, 0.2, 0.3]}, index=['A', 'B', 'C'])
print(df_mix)
# ? ?col_int ?col_float
# A ? ? ? ?0 ? ? ? ?0.1
# B ? ? ? ?1 ? ? ? ?0.2
# C ? ? ? ?2 ? ? ? ?0.3
print(df_mix.dtypes)
# col_int ? ? ? ?int64
# col_float ? ?float64
# dtype: object
print(df_mix.T)
# ? ? ? ? ? ? ?A ? ?B ? ?C
# col_int ? ?0.0 ?1.0 ?2.0
# col_float ?0.1 ?0.2 ?0.3
print(df_mix.T.dtypes)
# A ? ?float64
# B ? ?float64
# C ? ?float64
# dtype: object
即使再次轉(zhuǎn)置它也無法還原。需要應(yīng)用astype()來轉(zhuǎn)換數(shù)據(jù)類型。
?
print(df_mix.T.T)
# ? ?col_int ?col_float
# A ? ? ?0.0 ? ? ? ?0.1
# B ? ? ?1.0 ? ? ? ?0.2
# C ? ? ?2.0 ? ? ? ?0.3
print(df_mix.T.T.dtypes)
# col_int ? ? ?float64
# col_float ? ?float64
# dtype: object
元素為字符串str的字符串是對象類型。
df_mix2 = pd.DataFrame({'col_int': [0, 1, 2], 'col_float': [0.1, 0.2, 0.3], 'col_str': ['a', 'b', 'c']},
? ? ? ? ? ? ? ? ? ? ? ?index=['A', 'B', 'C'])
print(df_mix2)
# ? ?col_int ?col_float col_str
# A ? ? ? ?0 ? ? ? ?0.1 ? ? ? a
# B ? ? ? ?1 ? ? ? ?0.2 ? ? ? b
# C ? ? ? ?2 ? ? ? ?0.3 ? ? ? c
print(df_mix2.dtypes)
# col_int ? ? ? ?int64
# col_float ? ?float64
# col_str ? ? ? object
# dtype: object
print(df_mix2.T)
# ? ? ? ? ? ? ?A ? ?B ? ?C
# col_int ? ? ?0 ? ?1 ? ?2
# col_float ?0.1 ?0.2 ?0.3
# col_str ? ? ?a ? ?b ? ?c
print(df_mix2.T.dtypes)
# A ? ?object
# B ? ?object
# C ? ?object
# dtype: object
print(df_mix2.T.T)
# ? col_int col_float col_str
# A ? ? ? 0 ? ? ? 0.1 ? ? ? a
# B ? ? ? 1 ? ? ? 0.2 ? ? ? b
# C ? ? ? 2 ? ? ? 0.3 ? ? ? c
print(df_mix2.T.T.dtypes)
# col_int ? ? ?object
# col_float ? ?object
# col_str ? ? ?object
# dtype: object
視圖和復(fù)制
如果所有列都具有相同的數(shù)據(jù)類型,則T或transpose()將返回視圖。
原始對象和視圖對象共享內(nèi)存,因此更改一個(gè)元素會(huì)更改另一個(gè)元素。
df = pd.DataFrame({'X': [0, 1, 2], 'Y': [3, 4, 5]}, index=['A', 'B', 'C'])
print(df)
# ? ?X ?Y
# A ?0 ?3
# B ?1 ?4
# C ?2 ?5
df_T = df.T
print(df_T)
# ? ?A ?B ?C
# X ?0 ?1 ?2
# Y ?3 ?4 ?5
df_transpose = df.transpose()
print(df_transpose)
# ? ?A ?B ?C
# X ?0 ?1 ?2
# Y ?3 ?4 ?5
df.at['A', 'X'] = 100
print(df)
# ? ? ?X ?Y
# A ?100 ?3
# B ? ?1 ?4
# C ? ?2 ?5
print(df_T)
# ? ? ?A ?B ?C
# X ?100 ?1 ?2
# Y ? ?3 ?4 ?5
print(df_transpose)
# ? ? ?A ?B ?C
# X ?100 ?1 ?2
# Y ? ?3 ?4 ?5
如果每一列的數(shù)據(jù)類型dtype不同,則T或transpose()將生成一個(gè)副本。轉(zhuǎn)置的對象保留一個(gè)新的存儲(chǔ)區(qū),因此,如果更改一個(gè)的值,則另一個(gè)將保持不變。
df_mix = pd.DataFrame({'col_int': [0, 1, 2], 'col_float': [0.1, 0.2, 0.3]}, index=['A', 'B', 'C'])
print(df_mix)
# ? ?col_int ?col_float
# A ? ? ? ?0 ? ? ? ?0.1
# B ? ? ? ?1 ? ? ? ?0.2
# C ? ? ? ?2 ? ? ? ?0.3
df_mix_T = df_mix.T
print(df_mix_T)
# ? ? ? ? ? ? ?A ? ?B ? ?C
# col_int ? ?0.0 ?1.0 ?2.0
# col_float ?0.1 ?0.2 ?0.3
df_mix_transpose = df_mix.transpose()
print(df_mix_transpose)
# ? ? ? ? ? ? ?A ? ?B ? ?C
# col_int ? ?0.0 ?1.0 ?2.0
# col_float ?0.1 ?0.2 ?0.3
df_mix.at['A', 'col_int'] = 100
print(df_mix)
# ? ?col_int ?col_float
# A ? ? ?100 ? ? ? ?0.1
# B ? ? ? ?1 ? ? ? ?0.2
# C ? ? ? ?2 ? ? ? ?0.3
print(df_mix_T)
# ? ? ? ? ? ? ?A ? ?B ? ?C
# col_int ? ?0.0 ?1.0 ?2.0
# col_float ?0.1 ?0.2 ?0.3
print(df_mix_transpose)
# ? ? ? ? ? ? ?A ? ?B ? ?C
# col_int ? ?0.0 ?1.0 ?2.0
# col_float ?0.1 ?0.2 ?0.3
如果僅在后續(xù)過程中使用轉(zhuǎn)置的轉(zhuǎn)置,則不必?fù)?dān)心。以顯式創(chuàng)建副本。在transpose()中,當(dāng)參數(shù)copy設(shè)置為True時(shí),將生成一個(gè)副本。
df = pd.DataFrame({'X': [0, 1, 2], 'Y': [3, 4, 5]}, index=['A', 'B', 'C'])
print(df)
# ? ?X ?Y
# A ?0 ?3
# B ?1 ?4
# C ?2 ?5
df_T_copy = df.T.copy()
print(df_T_copy)
# ? ?A ?B ?C
# X ?0 ?1 ?2
# Y ?3 ?4 ?5
df_transpose_copy = df.transpose(copy=True)
print(df_transpose_copy)
# ? ?A ?B ?C
# X ?0 ?1 ?2
# Y ?3 ?4 ?5
df.at['A', 'X'] = 100
print(df)
# ? ? ?X ?Y
# A ?100 ?3
# B ? ?1 ?4
# C ? ?2 ?5
print(df_T_copy)
# ? ?A ?B ?C
# X ?0 ?1 ?2
# Y ?3 ?4 ?5
print(df_transpose_copy)
# ? ?A ?B ?C
# X ?0 ?1 ?2
# Y ?3 ?4 ?5
transpose()的參數(shù)副本默認(rèn)為False,如果可能,則生成視圖而不是副本。如上例所示,當(dāng)每列的數(shù)據(jù)類型dtype不同時(shí),即使它是默認(rèn)值(copy = False),也會(huì)生成一個(gè)副本。不一定是視圖。
原文鏈接:https://blog.csdn.net/qq_18351157/article/details/105931547
- 上一篇:沒有了
- 下一篇:沒有了
相關(guān)推薦
- 2023-02-26 flutter中的網(wǎng)絡(luò)請求數(shù)據(jù)獲取詳解_Android
- 2022-06-07 FreeRTOS實(shí)時(shí)操作系統(tǒng)臨界段保護(hù)場合示例_操作系統(tǒng)
- 2022-05-17 configure: error: Building GCC requires GMP 4.2+,
- 2022-05-13 linq中的限定操作符_實(shí)用技巧
- 2022-12-01 Git基礎(chǔ)學(xué)習(xí)之分支操作的示例詳解_相關(guān)技巧
- 2022-07-29 Docker容器數(shù)據(jù)卷技術(shù)介紹_docker
- 2022-06-26 Android如何使用圓形揭露動(dòng)畫巧妙地隱藏或顯示View詳解_Android
- 2022-07-06 Qt之使用GraphicsView框架實(shí)現(xiàn)思維導(dǎo)圖的示例_C 語言
- 欄目分類
-
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲(chǔ)小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯(cuò)誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡單動(dòng)態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支