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 有了解d3和topogram.js库的吗?有偿请教
  • ¥100 任意维数的K均值聚类
  • ¥15 stamps做sbas-insar,时序沉降图怎么画
  • ¥15 unity第一人称射击小游戏,有demo,在原脚本的基础上进行修改以达到要求
  • ¥15 买了个传感器,根据商家发的代码和步骤使用但是代码报错了不会改,有没有人可以看看
  • ¥15 关于#Java#的问题,如何解决?
  • ¥15 加热介质是液体,换热器壳侧导热系数和总的导热系数怎么算
  • ¥100 嵌入式系统基于PIC16F882和热敏电阻的数字温度计
  • ¥15 cmd cl 0x000007b
  • ¥20 BAPI_PR_CHANGE how to add account assignment information for service line