按行进行SUMIF和DATEDIF
创始人
2024-08-22 03:30:12
0

以下是一个按行进行SUMIF和DATEDIF的解决方法的代码示例:

import pandas as pd
from datetime import datetime

# 创建示例数据
data = {'Name': ['John', 'Emily', 'James', 'Amy'],
        'Start Date': ['2022-01-01', '2022-02-01', '2022-03-01', '2022-04-01'],
        'End Date': ['2022-01-31', '2022-02-28', '2022-03-31', '2022-04-30'],
        'Amount': [1000, 2000, 3000, 4000]}
df = pd.DataFrame(data)

# 将日期列转换为日期类型
df['Start Date'] = pd.to_datetime(df['Start Date'])
df['End Date'] = pd.to_datetime(df['End Date'])

# 计算每行的日期差
df['Duration'] = (df['End Date'] - df['Start Date']).dt.days

# 计算每行的总和
df['Total Amount'] = df.apply(lambda row: df.loc[(df['Name'] == row['Name']) & (df['Start Date'] <= row['Start Date']) & (df['End Date'] >= row['End Date']), 'Amount'].sum(), axis=1)

print(df)

这段代码使用了Pandas库来处理数据。首先,将日期列转换为日期类型,然后计算每行的日期差并将结果存储在'Duration'列中。接下来,使用apply函数来逐行计算总和。在lambda函数中,使用条件筛选出符合条件的行,并对它们的'Amount'列求和。最后,将结果存储在'Total Amount'列中。

输出结果如下:

   Name Start Date   End Date  Amount  Duration  Total Amount
0  John 2022-01-01 2022-01-31    1000        30          1000
1  Emily 2022-02-01 2022-02-28    2000        27          2000
2  James 2022-03-01 2022-03-31    3000        30          3000
3    Amy 2022-04-01 2022-04-30    4000        29          4000

以上代码示例中使用了Pandas库来处理数据,通过创建DataFrame对象来存储数据,然后使用Pandas提供的函数和方法进行计算和筛选操作。

相关内容

热门资讯

透视规律"wepok... 透视规律"wepoker怎么破解游戏"详细辅助可靠技巧(黑侠破解教程);《WPK辅助透视》‌:支持手...
透视透视挂"wepo... 透视透视挂"wepoker俱乐部辅助"详细辅助2025新版教程(开脚本视频辅助);1分钟了解详细教程...
透视玄学"大菠萝免费... 透视玄学"大菠萝免费辅助"详细辅助曝光教程(的辅助器软件)这是由厦门游乐互动科技有限公司精心打造的一...
透视美元局"德普辅助... 透视美元局"德普辅助软件"详细辅助必备教程(辅助器下载软件);原来确实真的有挂(需添加指定薇1367...
透视科技"wejok... 透视科技"wejoker辅助器怎么卖"详细辅助wepoke教程(底牌透视透视);原来确实真的有挂(需...
透视辅助"pokem... 透视辅助"pokemmo手机版修改器"详细辅助实用技巧(私人局俱乐部辅助教程)是一款可以让一直输的玩...
透视好牌"hhpok... 透视好牌"hhpoker脚本"详细辅助安装教程(辅助器是真的技巧)准备好在hhpoker脚本 ia的...
透视肯定"uupok... 这是一款非常优秀的uupoker有透视吗 ia辅助检测软件,能够让你了解到uupoker有透视吗中牌...
透视ai"wepok... 1、透视ai"wepoker有辅助器吗"详细辅助2025新版总结(网页版透视方法透明)2、进入游戏-...
透视免费"pokem... 透视免费"pokemmo脚本辅助器"详细辅助AA德州教程(免费辅助器软件);致您一封信;亲爱poke...