搜索

查看: 3123|回复: 11

[Python] Pandas中DataFrame对象转置(交换行列)

[复制链接]
发表于 2023-5-4 17:22:57 | 显示全部楼层 |阅读模式
Editor 2023-5-4 17:22:57 3123 11 看全部
DataFrame对象本质上是带有行列索引的二维矩阵,所以欲对DataFrame对象进行转置操作,需要交换行列索引,同时使二维矩阵转置。
首先创建一个DataFrame对象
import pandas as pd
list_test = [[1,2,3],[4,5,6],[7,8,9]]
index_colums =['A','B','C']
index_row = ['a','b','c']
df = pd.DataFrame(list_test, columns=index_colums,index=index_row)
print(df)
运行结果如下
   A  B  C
a  1  2  3
b  4  5  6
c  7  8  9

用如下代码进行转置操作
df_T = pd.DataFrame(df.values.T,columns=index_row,index=index_colums)
print(df_T)
我们可以看出,我们在参数中既通过df.values.T使得二维矩阵转置,又通过交换行列索引完成行列索引的变化,使得DataFrame对象完成转置。
运行结果如下        
   a  b  c
A  1  4  7
B  2  5  8
C  3  6  9

补充
有时候需要将一个DataFrame进行行和列的互换,此时可以用DataFrame.stack().unstack(0)进行互换。
示例:
import pandas as pd
from pandas import DataFrame
import numpy as np
np.random.seed(0)
matrix = np.random.rand(3,4)
print(matrix)
df = DataFrame(matrix, index=list('abc'), columns=list('xyzk'))
df

2023022209200721.png

2023022209200721.png


df = df.stack()df

2023022209200722.png

2023022209200722.png


df = df.unstack(0)df

2023022209200723.png

2023022209200723.png


到此这篇关于Pandas中DataFrame对象转置(交换行列)的文章就介绍到这了,更多相关Pandas DataFrame对象转置内容请搜索知鸟论坛以前的文章或继续浏览下面的相关文章希望大家以后多多支持知鸟论坛
回复

使用道具 举报

发表于 2023-6-28 19:29:35 | 显示全部楼层
贰十岁装成熟装s 2023-6-28 19:29:35 看全部
论坛不能没有像楼主这样的人才啊!我会一直支持知鸟论坛
回复

使用道具 举报

发表于 2023-6-28 22:22:06 | 显示全部楼层
墙和鸡蛋 2023-6-28 22:22:06 看全部
这个帖子不回对不起自己!我想我是一天也不能离开知鸟论坛
回复

使用道具 举报

发表于 2023-6-29 01:32:20 | 显示全部楼层
ffycxyw2274436 2023-6-29 01:32:20 看全部
论坛不能没有像楼主这样的人才啊!我会一直支持知鸟论坛
回复

使用道具 举报

发表于 2023-6-29 18:53:04 | 显示全部楼层
米老鼠和蓝精鼠v 2023-6-29 18:53:04 看全部
这东西我收了!谢谢楼主!知鸟论坛真好!
回复

使用道具 举报

发表于 2023-6-29 19:47:05 | 显示全部楼层
向往草原403 2023-6-29 19:47:05 看全部
楼主,我太崇拜你了!我想我是一天也不能离开知鸟论坛
回复

使用道具 举报

发表于 2023-6-29 20:51:24 | 显示全部楼层
普通人物怨 2023-6-29 20:51:24 看全部
论坛不能没有像楼主这样的人才啊!我会一直支持知鸟论坛
回复

使用道具 举报

发表于 2023-6-30 12:16:09 | 显示全部楼层
风吹吹蛋蛋疼风w 2023-6-30 12:16:09 看全部
楼主,大恩不言谢了!知鸟论坛是最棒的!
回复

使用道具 举报

发表于 2023-6-30 17:18:59 | 显示全部楼层
惜颜705 2023-6-30 17:18:59 看全部
我看不错噢 谢谢楼主!知鸟论坛越来越好!
回复

使用道具 举报

发表于 2023-6-30 21:53:53 | 显示全部楼层
123456833 2023-6-30 21:53:53 看全部
感谢楼主的无私分享!要想知鸟论坛好 就靠你我他
回复

使用道具 举报

  • 您可能感兴趣
点击右侧快捷回复 【请勿灌水】
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则 返回列表

RSS订阅| SiteMap| 小黑屋| 知鸟论坛
联系邮箱E-mail:zniao@foxmail.com
快速回复 返回顶部 返回列表