使用Python实现df的奇数列与偶数列调换位置,比如A列,B列,调换成B列,A列

点击上方“Python共享之家”,进行关注

回复“资源”即可获赠Python学习资料

残阳西入崦,茅屋访孤僧。

大家好,我是皮皮。

一、前言

前几天在Python铂金交流群【瑜亮老师】给大家出了一道Pandas数据处理题目,使用Python实现df的奇数列与偶数列调换位置,比如A列,B列,调换成B列,A列。

34d7e6b7ca8565fc725ebb3e18dcc9e4.png

下面是原始内容。

en = 'abcdef'
df = pd.DataFrame([[i + j for j in list(en)] for i in list(en)], columns=list(en.upper()), index=list(en.upper()))
print('源数据')
print(df)
# 请补全代码
#
print('转换后')
print(df)

结果如下图所示:

b2b4ea4a26f3404c6563063d19222751.png

二、实现过程

方法一

这里【kiddo】给出了一个解答,代码和结果如下图所示。

172ec74d0d09ace2d42f92859552f742.png

方法二

这里【月神】基于第一个方法,也给出了一个简化答案,7到16行就可以写成下面这样,代码如下所示:

df = df[[df.columns[index + (-1) ** index] for index in range(len(df.columns))]]
d05616dd5e632592c51d464f1f8d8861.png

运行之后,结果如下图所示:

cbbb24e10538e8960be4aba8fad3c191.png

方法三

【月神】后来又给了一个方法,代码如下所示:

import numpy as np
import pandas as pd

# 数据已经帮你写好,请补全剩余代码,实现上述功能。
en = 'abcdef'
df = pd.DataFrame([[i + j for j in list(en)] for i in list(en)], columns=list(en.upper()), index=list(en.upper()))
print('源数据')
print(df)
# 请补全代码
df = df[np.array((df.columns[1::2], df.columns[::2])).flatten('F')]
print('转换后')
print(df)

运行之后,结果如下图所示:

fbffb2f5e3a3dc4ee6da4d6df5c219ee.png

八仙过海,神仙操作,简直太强了!

三、总结

大家好,我是皮皮。这篇文章主要盘点了使用Python实现df的奇数列与偶数列调换位置,比如A列,B列,调换成B列,A列的问题,文中针对该问题给出了具体的解析和代码演示,一共3个方法,欢迎一起学习交流,我相信还有其他方法,如果你有的话,记得来我交流群分享噢!

最后感谢【瑜亮老师】出题,感谢【瑜亮老师】、【kiddo】、【月神】给出的代码和具体解析,感谢【冯诚】、【dcpeng】等人参与学习交流。

小伙伴们,快快用实践一下吧!如果在学习过程中,有遇到任何问题,欢迎加我好友,我拉你进Python学习交流群共同探讨学习。

b19692a6062b01722c1f2fa4e8154b1d.png

------------------- End -------------------

往期精彩文章推荐:

4cfcf30ef28417a9d2ddea11f6b2fd5e.png

欢迎大家点赞,留言,转发,转载,感谢大家的相伴与支持

想加入Python学习群请在后台回复【

万水千山总是情,点个【在看】行不行

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值