如何比较数据帧中的多个布尔值

2024-06-28 11:27:08 发布

您现在位置:Python中文网/ 问答频道 /正文

我有这样一个df:

         customer_id                       offer_id                   viewed_withintime completed_withintime
0   389bc3fa690240e798340f5a15918d5c    f19421c1d4aa40978ebb69ca19b0e20d    True           True
1   389bc3fa690240e798340f5a15918d5c    f19421c1d4aa40978ebb69ca19b0e20d    True           False
2   389bc3fa690240e798340f5a15918d5c    f19421c1d4aa40978ebb69ca19b0e20d    True           False

我想创建一个名为offer_succussful的新列,如果viewed_withintimecompleted_withintime都是True,那么offer_succussful的值是1,否则是0

这是我的密码:

# label offer_successful to 1 if an offer is viewed and completed within offer_endtime, if not, set it to 0
offer_success_merge['offer_successful'] = (offer_success_merge['completed_withintime'] == True) and (offer_success_merge['viewed_withintime'] == True)

这将返回错误:

ValueError: The truth value of a Series is ambiguous. Use a.empty, a.bool(), a.item(), a.any() or a.all().

有人可以帮我看看,不知道如何修改这段代码…提前谢谢


Tags: toidfalsetrueifismergesuccess
2条回答

您还可以使用:

df['offer_successful'] = (df['viewed_withintime']== True) & (df['completed_withintime']== True)

您可以使用numpy模块解决此问题:

import numpy as np
offer_success_merge['offer_successful'] = np.logical_and((offer_success_merge['completed_withintime'] == True), (offer_success_merge['viewed_withintime'] == True))

相关问题 更多 >