Janet1223 2022-09-09 09:59 采纳率: 60%
浏览 48
已结题

Python分组累加到和小于阈值 形成新的dataframe

img


有一组数想要使得累加到和小于阈值,例如10,然后输出成dataframe,理想是使得最后得到的组数最少,不过达不到就直接累加也可以。

img


我尝试了这个代码,但是出来的是list,想要转换成dataframe,或者每一组单独输出成一个dataframe

非常感谢

  • 写回答

2条回答 默认 最新

  • 怀念不必想念 2022-09-09 10:50
    关注

    改了下你的代码,新添加alllist 数组用于存储Splitlist,因为你没取成功一次数组就清除所以添加个alllist
    import pandas as pd

    df0 = [1, 2, 4, 2, 3, 5, 13]
    splistlist = []
    alllist = []
    max = 10
    for i in range((len(df0))):
    obj = df0[i]
    if obj <= max:
    splistlist.append(obj)
    max -= obj
    else:
    alllist.append(splistlist)
    splistlist = []
    splistlist.append(obj)
    max = 10 - obj
    alllist.append(splistlist)

    print(alllist)

    data2 = pd.DataFrame(alllist)
    data2.to_excel('./list.xlsx')

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

报告相同问题?

问题事件

  • 系统已结题 9月17日
  • 已采纳回答 9月9日
  • 赞助了问题酬金10元 9月9日
  • 创建了问题 9月9日

悬赏问题

  • ¥15 想通过pywinauto自动电机应用程序按钮,但是找不到应用程序按钮信息
  • ¥15 MATLAB中streamslice问题
  • ¥15 如何在炒股软件中,爬到我想看的日k线
  • ¥15 51单片机中C语言怎么做到下面类似的功能的函数(相关搜索:c语言)
  • ¥15 seatunnel 怎么配置Elasticsearch
  • ¥15 PSCAD安装问题 ERROR: Visual Studio 2013, 2015, 2017 or 2019 is not found in the system.
  • ¥15 (标签-MATLAB|关键词-多址)
  • ¥15 关于#MATLAB#的问题,如何解决?(相关搜索:信噪比,系统容量)
  • ¥500 52810做蓝牙接受端
  • ¥15 基于PLC的三轴机械手程序