题解 | #筛选某店铺最有价值用户中消费最多前5名#

筛选某店铺最有价值用户中消费最多前5名

https://www.nowcoder.com/practice/58655010a7c34e9fb2b7b491c3f79ca4

2022.8.16 提交完最后一道Pandas数据分析,有机会重头再做一遍

import pandas as pd
import numpy as np

sales = pd.read_csv("sales.csv")

down = sales.quantile(0.25)
mid = sales.quantile(0.5)
up = sales.quantile(0.75)

sales["R_Quartile"] = np.where(
    sales.recency <= down.recency,
    4,
    np.where(
        sales.recency <= mid.recency, 3, np.where(sales.recency <= up.recency, 2, 1)
    ),
)

sales["F_Quartile"] = np.where(
    sales.frequency <= down.frequency,
    1,
    np.where(
        sales.frequency <= mid.frequency,
        2,
        np.where(sales.frequency <= up.frequency, 3, 4),
    ),
)

sales["M_Quartile"] = np.where(
    sales.monetary <= down.monetary,
    1,
    np.where(
        sales.monetary <= mid.monetary, 2, np.where(sales.monetary <= up.monetary, 3, 4)
    ),
)

sales["RFMClass"] = (
    sales["R_Quartile"].map(str)
    + sales["F_Quartile"].map(str)
    + sales["M_Quartile"].map(str)
)

print(sales.head(5).loc[:, ["user_id", "recency", "frequency", "monetary", "RFMClass"]])

print()

sales.query("RFMClass == '444'").sort_values("monetary", ascending=False).head(5).loc[
    :, ["user_id", "recency", "frequency", "monetary", "RFMClass"]
]


全部评论

相关推荐

10-20 15:26
门头沟学院 Java
桥头牛油火锅:这个比例不正常,简历的话项目经历放中间,项目功能分点可以再明确点,前面加“·”或者“1 2 3”,另外简历上的照片可以去外面摄影店拍一下,以后也会用到的,hr筛人也是多少会看的,毕竟世界是一个巨大的卡颜局嘛,还有有些hr由于消息太多可能没看到,后面可能会回来找你,要简历的还会多一点,我也是普2本,比例大致是600:90:15:3,当然我实力不太够,拿的offer比较少,慢慢来吧
点赞 评论 收藏
分享
评论
3
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务