【问题标题】:Using loop to divide DF into several smaller DFs [duplicate]使用循环将 DF 分成几个较小的 DF [重复]
【发布时间】:2020-01-17 14:10:05
【问题描述】:

我正在尝试循环一个 DF 以创建一个较小的 DF,然后对该较小的 DF 执行其他步骤。完成后,我希望它在列表的下方继续执行相同的操作,直到我的原始 DF 中的所有行一次通过循环 100 行(不想要元组或其他数据格式,我真的需要每个人都在一个DF中)。

下面有我认为成功的代码。 开始 = 0 结束 = 99 对于 df 中的段: 段 = df.loc[开始:结束] 开始 = 开始+100 结束 = 结束+100

这仅适用于前 3 次传递,然后停止。我添加了一些代码来帮助诊断,但我仍然无法弄清楚它为什么停止。

print(len(df)
start = 0
end = 99
for segment in df:
    segment = df.loc[start:end]
    print(start,end)
    start = start+100
    end = end+100

结果: 2265 0 99 100 199 200 299

谁能告诉我为什么它停在第 299 行?如何让循环继续遍历整个 DF(2265 行)?

谢谢,

【问题讨论】:

  • 我假设您的 df 中有 3 列,当您执行 for segment in df 时,segment 实际上是一列的名称(在您重新分配其值之前),循环 for 确实3 次迭代,因为我认为 3 列

标签: python pandas loops dataframe indexing


【解决方案1】:

实际上这并没有帮助,因为它提供了一个列表,而不是一个 DF(如我所说)。但是,我能够在另一个线程中找到答案。感谢您的帮助!

Pandas DataFrame slicing with iteration

【讨论】:

    猜你喜欢
    • 2020-11-28
    • 2022-01-17
    • 2021-09-25
    • 2020-08-16
    • 2016-09-16
    • 1970-01-01
    • 1970-01-01
    • 2021-06-19
    • 2020-06-20
    相关资源
    最近更新 更多