按行进行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提供的函数和方法进行计算和筛选操作。

相关内容

热门资讯

安装Pillow时遇到了问题:... 遇到这个问题,可能是因为缺少libwebpmux3软件包。解决方法是手动安装libwebpmux3软...
安装React Native时... 当安装React Native时出现构建错误的情况,可以尝试以下解决方法:确保已经安装了最新版本的C...
安装Python库"... 安装Python库"firedrake"的解决方法如下:打开终端或命令提示符(Windows系统)。...
安装Rails时构建webso... 在安装Rails时,如果构建websocket-driver时发生错误,可以尝试以下解决方法:更新系...
安装react-native-... 要安装react-native-onesignal并在应用关闭时仍能接收通知,可以按照以下步骤进行:...
按转换模式过滤日志【%t】。 要按照转换模式过滤日志,可以使用正则表达式来实现。下面是一个示例代码,使用Java语言的Patter...
Apache Nifi在Kub... Apache Nifi可以在Kubernetes上运行,并且已经准备好用于生产环境。下面是一个使用H...
安装ug未能链接到许可证服务器 安装UG未能链接到许可证服务器是UG用户在安装软件时常遇到的问题之一。该问题的解决方法需要技术向的知...
安装React-Scripts... 这是因为React-Scripts使用Facebook工具包中的一些脚本。 joinAdIntere...
安装React Native时... 安装React Native时可能会出现各种错误,下面是一些常见错误和解决方法的代码示例:Error...