python高潜用户分析

高潜用户应该具有的特征:

1)必须有购买行为;
2)对一个商品购买,并且有其他交互行为(如浏览、点击、收藏等)
3)  最早交互时间跟购买时间要大于1

需要处理的数据:自行下载

字段名称         意义                字段名称         意义
user_id         用户编号             user_id         用户编号
age             年龄                 sku_id         商品编号
sex             性别                 type           行为类型
user_lv_cd      用户级别             time            行为时间
browse_num      浏览数               ate             品类ID
addcart num     加购数
delcart num     删购数
buy_num         购买数
favor_num       收藏数
click_num       点击数
# 读取数据
path = r'E:\python\python项目\数据分析\用户画像分析\action.csv'
chunker = pd.read_csv(path, iterator=True)
loop = True
chunksize = 10000  # 设置每次读取10000条数据
chunks = []
while loop:
    try:
        chunk = chunker.get_chunk(chunksize)[['user_id', 'sku_id', 'type', 'time', 'cate']]
        chunks.append(chunk)
    except StopIteration:
        loop = False
        print('文件读取完毕')
# print(chunks)
action = pd.concat(chunks, ignore_index=True)

这里我们先读action.csv ,由于数据量比较大,(数据太大读不出来,程序会报错)我们需要按块读取,每次读一点。

数据清洗:

这个表的数据基本可以算是比较好的,不需要数据清洗。

#查看是否需要进行数据清洗
print(action.isnull().sum())  # 无空值
print(action.duplicated().sum()) # 重复值
# 异常值
print(action.describe())

#我们在运行的时候发现 时间这一列类型不太对,所以我们就转换一下格式
print(action.info())

#类型转换
action['time'] = pd.to_datetime(action['time'])
action['user_id'] = action['user_id'].astype('int')

数据筛选:

1:筛选出购买行为的用户。

action.csv 表中 type列是    行为类型

print(action['type'].value_counts())  # type     行为类型 已经对type进行了分类,我们只需要找到数值最低的,就是购买的用户

我们运行查看行为类型后发现,已经是有分好类了,1,2,3,4,5,6.这六种类型,分别对应了多少行。这样我们目前还是不知道那一行是购买记录。所以可以根据实际分析,购买的行为应该是最少的。所以我们就定位到行为为4的购买记录。

然后进行筛选出行为4的客户如下图所示。

# 行为4的客户
action_type4 = action[action['type'] == 4]
print(action_type4)

# 计算每一类商品每个用户的最后购买时间
ac_lastbuytime = action_type4.groupby(by=['cate', 'user_id'])['time'].apply(lambda x: x.max())
print(ac_lastbuytime.head())

# 最早与该商品发生交互的日期
# ac_lastbuytime 表id具有唯一性 与总表进行合并,
ac_all_buy = pd.merge(ac_lastbuytime, action, left_on='user_id', right_on='user_id')
print(ac_all_buy.head())

ac_firsttime = ac_all_buy.groupby(by='user_id')['time_y'].apply(lambda x: x.min())

df = pd.merge(ac_lastbuytime, ac_firsttime.to_frame(), on='user_id')
df.columns = ['buy_time', 'ac_time']
print(df)

#计算时间差

df['days'] = (pd.to_datetime(df['buy_time']) - pd.to_datetime(df['ac_time'])).dt.days
print(df)

# 获取高潜力用户
high_pot = df[df['days'] > 1]
print(high_pot)

上面这一段是筛选出高潜用户。

筛选出来后,我们对客户等级进行分类,然后生成一个图表。

# 用户表

user = pd.read_csv(r'E:\python\python项目\数据分析\用户画像分析\user.csv')
# 表合并
user_high = pd.merge(user, high_pot, on='user_id')


#去重
user_high.drop_duplicates(subset=['user_id'],inplace=True)
print(user_high)

# 用户等级分布
user_lv_count = user_high['user_lv_cd'].value_counts()
print(user_lv_count)

# 数据可视化
num = user_lv_count.values.tolist()#转列表
lev = user_lv_count.index.tolist()
data_pair = [(i,j)for i ,j in zip(lev,num)]
pie = (Pie()
       .add('',data_pair)
       .set_global_opts(tooltip_opts=opts.TooltipOpts(is_show=True,formatter='等级{b}:{d}%'),
                        title_opts={'text':'高潜用户等级占比'}))
pie.render_notebook()

pie.render("1.html")

使用pyecharts库生成一个HTML文件,这个库做出了的表比较好看,有一点动画效果。

import pandas as pd
from pyecharts.charts import Pie
import pyecharts.options as opts

# 读取数据
path = r'E:\python\python项目\数据分析\用户画像分析\action.csv'
chunker = pd.read_csv(path, iterator=True)
loop = True
chunksize = 10000  # 设置每次读取10000条数据
chunks = []
while loop:
    try:
        chunk = chunker.get_chunk(chunksize)[['user_id', 'sku_id', 'type', 'time', 'cate']]
        chunks.append(chunk)
    except StopIteration:
        loop = False
        print('文件读取完毕')
# print(chunks)
action = pd.concat(chunks, ignore_index=True)
# print(action.head())
# print(action.info())

# 数据清洗

# print(action.isnull().sum())  # 无空值

# 重复值
# print(action.duplicated().sum())

# 异常值
# print(action.describe())


#类型转换
action['time'] = pd.to_datetime(action['time'])
action['user_id'] = action['user_id'].astype('int')
#
# print(action.info())
#
print(action['type'].value_counts())  # type     行为类型 已经对type进行了分类,我们只需要找到数值最低的,就是购买的用户
#
# 行为4的客户
action_type4 = action[action['type'] == 4]
print(action_type4)

# 计算每一类商品每个用户的最后购买时间
ac_lastbuytime = action_type4.groupby(by=['cate', 'user_id'])['time'].apply(lambda x: x.max())
print(ac_lastbuytime.head())

# 最早与该商品发生交互的日期
# ac_lastbuytime 表id具有唯一性 与总表进行合并,
ac_all_buy = pd.merge(ac_lastbuytime, action, left_on='user_id', right_on='user_id')
print(ac_all_buy.head())
#
ac_firsttime = ac_all_buy.groupby(by='user_id')['time_y'].apply(lambda x: x.min())

df = pd.merge(ac_lastbuytime, ac_firsttime.to_frame(), on='user_id')
df.columns = ['buy_time', 'ac_time']
print(df)

# 计算时间差

df['days'] = (pd.to_datetime(df['buy_time']) - pd.to_datetime(df['ac_time'])).dt.days
print(df)

# 获取高潜力用户
high_pot = df[df['days'] > 1]
print(high_pot)
#
# 用户表

user = pd.read_csv(r'E:\python\python项目\数据分析\用户画像分析\user.csv')
# 表合并
user_high = pd.merge(user, high_pot, on='user_id')


#去重
user_high.drop_duplicates(subset=['user_id'],inplace=True)
print(user_high)

# 用户等级分布
user_lv_count = user_high['user_lv_cd'].value_counts()
print(user_lv_count)

# 数据可视化
num = user_lv_count.values.tolist()#转列表
lev = user_lv_count.index.tolist()
data_pair = [(i,j)for i ,j in zip(lev,num)]
pie = (Pie()
       .add('',data_pair)
       .set_global_opts(tooltip_opts=opts.TooltipOpts(is_show=True,formatter='等级{b}:{d}%'),
                        title_opts={'text':'高潜用户等级占比'}))
pie.render_notebook()

pie.render("1.html")

源码如下:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
京东JDdata算法大赛-高潜用户购买意向预测是一个以数据挖掘和机器学习为基础的竞赛项目,其目标是通过分析京东平台上的用户行为数据,预测用户对商品的购买意向。通过这个比赛,京东希望能够进一步提高用户购买转化率,提升用户的购物体验。 在比赛中,参赛者需要利用提供的京东用户行为数据,如用户的购物记录、浏览记录、搜索记录等,以及商品的相关信息,通过建立有效的模型,预测用户是否有购买某种商品的意向。这个预测结果对于京东来说具有重要意义,可以帮助京东优化推荐系统,提供更为个性化的商品推荐,从而吸引更多的用户进行购买。 为了参赛者能够更好地完成这个任务,京东提供了大量的数据和工具。参赛者可以自由使用这些数据和工具进行分析和建模,并提交预测结果。在整个比赛过程中,参赛者可以通过不断地调整模型参数和特征工程,提升模型的预测能力。 参与这个比赛可以带来很多好处。首先,参赛者可以通过实践学习数据挖掘和机器学习的相关知识和技术,提高自己在这个领域的能力。其次,通过分析京东平台上的数据,参赛者可以深入了解用户的消费习惯,洞察用户的购买行为,为企业提供有价值的业务洞见。最后,成功的参赛者还有机会获得丰厚的奖金和荣誉,进一步提升个人的社会影响力。 总之,京东JDdata算法大赛-高潜用户购买意向预测是一个很有意义的竞赛项目,对于参赛者和京东来说都具有重要的价值。通过这个比赛,可以促进数据挖掘和机器学习技术的发展,提升京东的推荐系统,为用户提供更好的购物体验。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

胖子是个潜力股

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值