Janet1223 2022-09-09 07:22 采纳率: 60%
浏览 102
已结题

Python 某列值累加求和到特定值后重置重新开始求和

img


我有一列数值 我希望他们几个累加值要小于等于10,取小于10的最大累加值,一旦大于10就保留原值

img


我尝试过这样的代码,但是他会保留到大于我想要的阈值10w后的一位

img

想知道有没有什么解决方法

  • 写回答

5条回答 默认 最新

  • onthornsilay 2022-09-09 09:09
    关注
    original_value = [1,2,3,5,5,9,13]  
    lastvalue = original_value[0]   # 把last value设为第一个值
    newcum = []
    
    for i in original_value[1:]:                        # 从第二个值开始
        if lastvalue + i > 10:                            # 若加上新值已经超过了阈值
            newcum.append(lastvalue)            # 把已经有的值填入
            lastvalue = i                                    # 更新last value(包含新值大于10的情况)
        else:
            lastvalue += i                                  # 若不超过即更新last value
    
    newcum.append(lastvalue)                    # 最后一个值,在循环中不会填入,所以需要单独操作
    # newcum : [6,10,9,13]                          # 得到目标
    
    

    然后将original替换为df['金额']即可,可用

    original = list(df['金额'])
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(4条)

报告相同问题?

问题事件

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

悬赏问题

  • ¥15 2024-五一综合模拟赛
  • ¥15 如何将下列的“无限压缩存储器”设计出来
  • ¥15 下图接收小电路,谁知道原理
  • ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
  • ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
  • ¥15 手机接入宽带网线,如何释放宽带全部速度
  • ¥30 关于#r语言#的问题:如何对R语言中mfgarch包中构建的garch-midas模型进行样本内长期波动率预测和样本外长期波动率预测
  • ¥15 ETLCloud 处理json多层级问题
  • ¥15 matlab中使用gurobi时报错
  • ¥15 这个主板怎么能扩出一两个sata口