在药王山讲芬兰语的鼠尾草 2023-03-11 23:09 采纳率: 50%
浏览 20
已结题

python 删除某些行 drop


cc = data.fillna(9999)
    for i in range(cc.shape[0]):
        print(cc.loc[i, '6'])
        if cc.loc[i, '6'] != 9999:
            bb = cc.drop([i])
    print(bb)

cc为

         6            7     8
0     9999          2-1   3-1
1  1-2 1-3         9999   3-1
2      1-1  2-1 2-2 2-3   3-2
3      1-4         9999  9999
4     9999          2-2  9999
5      1-2         9999   3-3
6     9999          2-3   3-3
7     9999         9999   3-3
8     9999         9999  9999


最后打印的bb和cc一样,并没有把cc的‘6’列里不为9999的行删除
我调试后发现bb = cc.drop([i]) 这行代码是运行了的,整个程序也没报错,但为什么最后没有删除呢?

  • 写回答

1条回答 默认 最新

  • MarkHan_ 2023-03-12 00:23
    关注

    该回答引用GPTᴼᴾᴱᴺᴬᴵ
    在你的循环中,每次都重新创建了一个bb的DataFrame。这意味着在每次迭代中,都将从cc中删除一行,并将结果存储在新的bb DataFrame中。但是,由于在每次迭代中都创建了一个新的bb DataFrame,因此最终的结果只包含最后一次循环中删除的行,而之前的删除操作已经被覆盖了。

    如果你想保留删除行后的DataFrame,你可以像下面这样修改你的代码:

    cc = data.fillna(9999)
    bb = cc.copy()  # 创建一个新的 DataFrame 以保存删除行后的结果
    for i in range(cc.shape[0]):
        print(cc.loc[i, '6'])
        if cc.loc[i, '6'] != 9999:
            bb = bb.drop([i])
    print(bb)
    
    
    

    这里创建了一个新的 DataFrame bb,并将其初始化为与 cc 相同的值。在每次迭代中,从 bb 中删除指定的行,并将删除后的结果存储回 bb 中。这样,最终的结果将包含所有删除操作后的行。

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

报告相同问题?

问题事件

  • 系统已结题 3月20日
  • 已采纳回答 3月12日
  • 修改了问题 3月11日
  • 创建了问题 3月11日

悬赏问题

  • ¥60 请查询全国几个煤炭大省近十年的煤炭铁路及公路的货物周转量
  • ¥15 请帮我看看我这道c语言题到底漏了哪种情况吧!
  • ¥66 如何制作支付宝扫码跳转到发红包界面
  • ¥15 pnpm 下载element-plus
  • ¥15 解决编写PyDracula时遇到的问题
  • ¥15 有没有人能解决下这个问题吗,本人不会编程
  • ¥15 plotBAPC画图出错
  • ¥30 关于#opencv#的问题:使用大疆无人机拍摄水稻田间图像,拼接成tif图片,用什么方法可以识别并框选出水稻作物行
  • ¥15 Python卡尔曼滤波融合
  • ¥20 iOS绕地区网络检测