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

请教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日

悬赏问题

  • ¥20 java在应用程序里获取不到扬声器设备
  • ¥15 echarts动画效果的问题,请帮我添加一个动画。不要机器人回答。
  • ¥60 许可证msc licensing软件报错显示已有相同版本软件,但是下一步显示无法读取日志目录。
  • ¥15 Attention is all you need 的代码运行
  • ¥15 一个服务器已经有一个系统了如果用usb再装一个系统,原来的系统会被覆盖掉吗
  • ¥15 使用esm_msa1_t12_100M_UR50S蛋白质语言模型进行零样本预测时,终端显示出了sequence handled的进度条,但是并不出结果就自动终止回到命令提示行了是怎么回事:
  • ¥15 前置放大电路与功率放大电路相连放大倍数出现问题
  • ¥30 关于<main>标签页面跳转的问题
  • ¥80 部署运行web自动化项目
  • ¥15 腾讯云如何建立同一个项目中物模型之间的联系