m0_65962044 2022-01-15 13:33 采纳率: 100%
浏览 72
已结题

请教pandas进行drop和reset_index以后会多出几列

代码如下,目的是从df中一行行取出,将'B’列相等的行存放到a,并将这些行从df中删除
操作以后a中多出两列分别是level_0和index,df中多出level_0一列

import pandas as pd

df = pd.DataFrame([['a', 1, 'a1'], ['a', 1, 'a2'], ['b', 2, 'b1'], ['b', 2, 'b2'], ['c', 3, 'c1']])
df.columns = ['A', 'B', 'C']

x = df.iloc[0]['B']
a = pd.DataFrame(columns=['A', 'B', 'C'])
while True:
    if x == df.iloc[0]['B']:  # 判断是否与第一行时间相等
        a = a.append(df.iloc[0, :])  # 加入存储队列
        df.drop(0, inplace=True)
        df.reset_index(inplace=True)

    else:
        break
a.reset_index(inplace=True)
print(a)
print(df)


显示结果:

level_0 A B C index
0 0 a 1 a1 NaN
1 0 a 1 a2 1.0
level_0 index A B C
0 1 2 b 2 b1
1 2 3 b 2 b2
2 3 4 c 3 c1

Process finished with exit code 0

  • 写回答

1条回答 默认 最新

  • heianduck 2022-01-15 13:54
    关注

    这样?

    img

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 1月23日
  • 已采纳回答 1月15日
  • 创建了问题 1月15日

悬赏问题

  • ¥15 删除虚拟显示器驱动 删除所有 Xorg 配置文件 删除显示器缓存文件 重启系统 可是依旧无法退出虚拟显示器
  • ¥15 vscode程序一直报同样的错,如何解决?
  • ¥15 关于使用unity中遇到的问题
  • ¥15 开放世界如何写线性关卡的用例(类似原神)
  • ¥15 关于并联谐振电磁感应加热
  • ¥60 请查询全国几个煤炭大省近十年的煤炭铁路及公路的货物周转量
  • ¥15 请帮我看看我这道c语言题到底漏了哪种情况吧!
  • ¥66 如何制作支付宝扫码跳转到发红包界面
  • ¥15 pnpm 下载element-plus
  • ¥15 解决编写PyDracula时遇到的问题