keepononon_____ 2021-09-14 23:21 采纳率: 77.8%
浏览 39
已结题

请问我这个为什么只能删掉最后一个负值行,前面的都删不了呢?



请问我这个为什么只能删掉最后一个负值行,前面的都删不了呢?
import pandas as pd
from pandas import DataFrame
from openpyxl import load_workbook
wb = pd.read_excel('Aged analysis.xlsx',sheet_name='Red')
DataFrame(wb).to_excel('df_new.xlsx',sheet_name='Red',index=False,header=True)
for j in range(0, len(wb.index)):
   # print(j)
    if wb.iat[j, 2]<0:
        print(j)
        data = wb.drop(index=j)
        data.to_excel('df_new.xlsx')
 

  • 写回答

2条回答 默认 最新

  • CSDN专家-HGJ 2021-09-15 00:50
    关注

    主要原因是在循环中对行数据删除以后结果没有保存,而在读取时是原来的数据框,当j值循环到后面时,只会删去最后读取的符合条件的那行。如果要实现题中要求,需要这样:

    from openpyxl import load_workbook
    import pandas as pd
    
    wb = pd.read_excel('t913.xlsx', sheet_name='red',header=None)
    df=wb.copy()
    for j in range(0,len(wb.index)):
       # print(j)
        if wb.iat[j, 2] < 0:
            df = df.drop(index=j)
            print(df)
    df.to_excel('t913_t.xlsx',header=None,index=None)
    

    如果解答对你有帮助,请点击我回答的右上方采纳按钮给予支持。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

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

悬赏问题

  • ¥15 请完成下列相关问题!
  • ¥15 drone 推送镜像时候 purge: true 推送完毕后没有删除对应的镜像,手动拷贝到服务器执行结果正确在样才能让指令自动执行成功删除对应镜像,如何解决?
  • ¥15 求daily translation(DT)偏差订正方法的代码
  • ¥15 js调用html页面需要隐藏某个按钮
  • ¥15 ads仿真结果在圆图上是怎么读数的
  • ¥20 Cotex M3的调试和程序执行方式是什么样的?
  • ¥20 java项目连接sqlserver时报ssl相关错误
  • ¥15 一道python难题3
  • ¥15 牛顿斯科特系数表表示
  • ¥15 arduino 步进电机