
在处理包含时间序列数据的dataframe时,我们经常会遇到需要根据某个特定日期对数据进行分组汇总的需求。例如,在一个包含多个月份销售额的表格中,每行代表一个产品,并指定一个“参考日期”,我们需要计算该产品在参考日期“之前”和“之后”的销售总额。本教程将详细阐述如何利用pandas库的强大功能,优雅地解决这类问题。
假设我们有一个DataFrame,其结构如下所示:
我们的目标是为每行数据,基于其Date列的值,计算所有日期列中早于Date的数值总和(Before)以及晚于或等于Date的数值总和(After),并将这两个总和作为新列添加到原始DataFrame中。
解决此问题的关键在于数据重塑(Reshaping)、条件判断和分组聚合。具体步骤如下:
首先,我们创建一个示例DataFrame来模拟上述场景:
import pandas as pd
import numpy as np
# 创建示例DataFrame
data = {
'Code': ['12345', '12346', '12347'],
'202001': [1000, 999, 1983],
'202002': [1001, 1000, 1984],
'202003': [1002, 1001, 1985],
'202004': [1003, 1002, 1986],
'202005': [1004, 1003, 1987],
'202006': [1005, 1003, 1988],
'202007': [3006, 1005, 1989],
'202008': [1007, 1006, 1990],
'202009': [1008, 1007, 1991],
'202010': [1009, 1008, 1992],
'202011': [1010, 1009, 1993],
'202012': [1011, 1010, 1994],
'Date': ['202004', '202006', '202010']
}
df = pd.DataFrame(data)
print("原始DataFrame:")
print(df)核心处理代码:
# 1. 数据重塑 (melt)
# 将除 'Code' 和 'Date' 以外的所有列转换为长格式
tmp = df.melt(['Code', 'Date'])
# 2. 数据类型统一
# 确保 'Date' 列和 'variable' (原始日期列名) 列都是字符串类型,便于比较
tmp = tmp.astype({'Date': str, 'variable': str})
# 3. 条件判断与分类 (assign with np.where)
# 比较 'Date' (每行的参考日期) 和 'variable' (当前数据点的日期)
# 如果 'Date' 大于 'variable',则为 'Before',否则为 'After'
tmp = tmp.assign(col=lambda d: np.where(d['Date'].gt(d['variable']), 'Before', 'After'))
# 4. 分组聚合 (groupby.sum)
# 按 'Code' 和新生成的 'col' (Before/After) 分组,并对 'value' 求和
tmp = tmp.groupby(['Code', 'col'])['value'].sum()
# 5. 结果重塑 (unstack)
# 将 'col' 从行索引转换为列,形成 'Before' 和 'After' 两列
# 并确保列顺序为 ['Before', 'After']
tmp = tmp.unstack('col')[['Before', 'After']]
# 6. 合并结果 (merge)
# 将计算出的 'Before' 和 'After' 列合并回原始DataFrame
# 使用 'Code' 列进行左连接,因为 'tmp' 的索引是 'Code'
out = df.merge(tmp, left_on='Code', right_index=True, how='left')
print("\n处理后的DataFrame:")
print(out)输出结果:
原始DataFrame:
Code 202001 202002 202003 202004 202005 202006 202007 202008 202009 202010 202011 202012 Date
0 12345 1000 1001 1002 1003 1004 1005 3006 1007 1008 1009 1010 1011 202004
1 12346 999 1000 1001 1002 1003 1003 1005 1006 1007 1008 1009 1010 202006
2 12347 1983 1984 1985 1986 1987 1988 1989 1990 1991 1992 1993 1994 202010
处理后的DataFrame:
Code 202001 202002 202003 202004 202005 202006 202007 202008 202009 202010 202011 202012 Date Before After
0 12345 1000 1001 1002 1003 1004 1005 3006 1007 1008 1009 1010 1011 202004 3003 11063
1 12346 999 1000 1001 1002 1003 1003 1005 1006 1007 1008 1009 1010 202006 5005 7048
2 12347 1983 1984 1985 1986 1987 1988 1989 1990 1991 1992 1993 1994 202010 17883 5979本教程提供了一种高效且灵活的方法,利用Pandas的melt、assign、groupby、unstack和merge等组合操作,实现了根据每行特定日期对DataFrame进行时间段划分并计算总和的功能。这种方法不仅代码简洁,而且逻辑清晰,能够很好地应对此类数据分析需求,极大地提高了数据处理的效率和灵活性。掌握这种数据重塑和聚合的技巧,对于进行复杂的时间序列数据分析至关重要。
以上就是利用Pandas高效计算DataFrame中指定日期前后数据总和的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号