商务服务
Python大数据-对淘宝用户的行为数据分析
2024-11-17 23:53

一、项目背景

Python大数据-对淘宝用户的行为数据分析


  • 通过对2014年11月17日至2014年12月17日之间数据进行合并,获得该月用户的行为数据,数据量在一千万条左右。

  • 本次数据是在网上获取的来源于数据集-阿里云天池,不在进行抓取或收集,大家可以看这篇文章Python爬虫-抓取数据到可视化全流程的实现,详细的写了数据抓取的过程

  • 使用的主要工具:python --jupyter notebook

二、项目目标


  • 用户行为分析是对用户在产品上的产生的行为及行为背后的数据进行分析,通过本次分析希望可以实现

  • 1、通过构建用户行为模型和用户画像来改变产品决策,实现精细化运营,指导业务增长

2、 在产品运营过程中,对用户行为的数据进行收集、存储、跟踪、分析与应用等可以找到实现用户自增长的存在的问题、群体特征与目标用户

三、分析思路

==========

  • 主要从以下四个维度对用户行为进行分析和建议

  • 1、用户的行为习惯分析:利用pv、uv等指标,分析用户活跃的时间段和趣事,熟悉用户行为的时间模式

  • 2、用户的行为转换情况分析:通过采用漏斗模型从单击浏览到支付购买的各个阶段对用户行为进行分析,确定各个环节的流失率,并提出相应的改善建议

  • 3、用户偏好分析:根据商品的点击、收藏、加购、购买频率,探索用户对商品的购买偏好,制定对不同商品、不同用户之间的营销策略

  • 4、核心用户分析:找出最具有价值的核心用户群,考虑针对该群体的营销策略,针对这个群体用户行为推送个性化推送,优惠券等。

四、数据清洗


  • 首先该数据是在多个文件下的CSV文件,通过递归对文件夹内所有文件进行查询,并合并了所有的指定文件,具体的操作步骤大家可以看Python遍历目录下的所有文件、读取、千万条数据合并详解这篇文章,里边详细的写了如何遍历所有文件夹,如何组合,如何批量的打开文件目录下的所有文件,并对多文件下的文件进行合并,本文就不再赘述数据合并的过程了,直接采用合并后的数据,大家不懂可以看我的以上两盘博客,写的很详细。

  • 1、读取查看数据的基本信息和数据的完整性

data=final_data

data.head()

查看一下我们合并后表格的情况,可以发现目前表格的列数为7列

  • Python大数据-对淘宝用户的行为数据分析 ​

其中’Unnamed: 0’,‘user_geohash’(有缺失)两列数据我们在分析时不涉及对这两列数据进行删除

import pandas as pd

final_data.drop([‘Unnamed: 0’,‘user_geohash’],axis=1,inplace=True)

final_data.head()

Python大数据-对淘宝用户的行为数据分析 ​

成功进行删除,检查数据类型

data.dtypes

Python大数据-对淘宝用户的行为数据分析

2、一致化处理

  • 可以发现目前time是object型的因为分析涉及到时间、天、小时,所以,要把数据集里的时间戳列,即time_stamp列转化为日期。

data[‘date’] = data[‘time’].map(lambda x:x.split(’ ')[0])

data[‘hour’] = data[‘time’].map(lambda x:x.split(’ ')[1])

data[‘date’]=pd.to_datetime(data[‘date’])

data[‘hour’] = data[‘hour’].astype(‘int32’)

data.head()

data.dtypes

  • Python大数据-对淘宝用户的行为数据分析

Python大数据-对淘宝用户的行为数据分析

可以看到目前date和Hour的类型已经成功转换,符合我们的预期,查看表格中是否有空数据,并查看一下表格的量

  • 3、查看是否有缺失值

data.isnull().sum()

data.shape

Python大数据-对淘宝用户的行为数据分析 ​Python大数据-对淘宝用户的行为数据分析 ​

可以看到数据中并没有空数据,数据的规模在1000万左右,分为6列,依次为用户id、商品id、用户行为类型、时间。其中用户行为类型中1代表点击(当做pv,2代表collect(收藏,3代表cart(加入购物车)数据较为完整,不需要继续进行清洗,对数据进行分析

五、数据分析


  • 流量指标分析:流量指标是指用户在某一个网站操作的每一个步骤记录的指标,埋点数据,PV是指其浏览量,UV代表独立访客数,访问深度代表每个独立访客的浏览量,页面跳出率 则是指浏览某个页面离开的次数/这个页面的全部访问次数

1、不同时间下PV、UV的流量变化情况


1)每天的PV、UV变化情况

  • 首先计算一下总流量

import pandas as pd

import numpy as np

import matplotlib.pyplot as plt

import os

data.shape[0]

总流量为12256906,在计算一下日平均流量、日平均独立访客数

##日PV

pv_daily = data.groupby([‘date’])[‘user_id’].count().reset_index().rename(columns={‘user_id’:‘pv_daily’})

pv_daily.head()

Python大数据-对淘宝用户的行为数据分析

  • 日平均独立访客数与日平均流量的区别在于要进行去重

##日UV

uv_daily = data.groupby([‘date’])[‘user_id’].apply(lambda x:x.drop_duplicates().count()).reset_index().rename(columns={‘user_id’:‘uv_daily’})

uv_daily.head()

s=uv_daily[‘uv_daily’]

pv_daily[‘uv_daily’]=s

pv_daily

将两表合并

  • Python大数据-对淘宝用户的行为数据分析

plt.figure(figsize=(40,20),dpi=80)

font={

“family”:“kaiti”,

“size”:‘30’

}

plt.rc(“font”,**font)

plt.subplot(211)#在第一个位置日平均流量图

plt.plot(pv_daily[‘date’],pv_daily[‘pv_daily’],‘co-’)

plt.gca().xaxis.set_major_formatter(mdates.DateFormatter(‘%m/%d’))

plt.gca().xaxis.set_major_locator(mdates.DayLocator()) # 按月显示,按日显示的话,将MonthLocator()改成DayLocator()

plt.gcf().autofmt_xdate()

ax=plt.gca()

ax.spines[“top”].set_color(“w”)

ax.spines[“bottom”].set_color(“r”)

ax.spines[“left”].set_color(“r”)

ax.spines[“right”].set_color(“w”)

plt.gcf().autofmt_xdate()

#设置X轴标签

plt.xlabel(“时间”)

#设置y轴标签

plt.ylabel(“日平均流量统计图”)

plt.title(‘日平均流量’)

plt.figure(figsize=(40,20), dpi=80)

plt.subplot(212)#第二个位置绘制日平均独立访客数

plt.plot(pv_daily[‘date’],pv_daily[‘uv_daily’],‘yo-’)

plt.gca().xaxis.set_major_formatter(mdates.DateFormatter(‘%m/%d’))

plt.gca().xaxis.set_major_locator(mdates.DayLocator())

ax=plt.gca()

ax.spines[“top”].set_color(“w”)

ax.spines[“bottom”].set_color(“r”)

ax.spines[“left”].set_color(“r”)

ax.spines[“right”].set_color(“w”)

plt.title(‘日独立访问客流量’)

plt.gcf().autofmt_xdate()

#设置X轴标签

plt.xlabel(“时间”)

#设置y轴标签

plt.ylabel(“日独立访客量统计图”)

plt.show()

绘制子图,将日平均流量和独立访问客数放在一起进行对比分析

  • Python大数据-对淘宝用户的行为数据分析

  • 可以发现在双十二当天是流量和独立访客数的高峰,在平常波动不大

每天时刻数据

pv_daily_hour = data.groupby([‘hour’])[‘user_id’].count().reset_index().rename(columns={‘user_id’:‘pv’})

uv_daily_hour = data.groupby([‘hour’])[‘user_id’].apply(lambda x:x.drop_duplicates().count()).reset_index().rename(columns={‘user_id’:‘uv’})

pv_daily_hour.head()

uv_daily_hour.head()

Python大数据-对淘宝用户的行为数据分析Python大数据-对淘宝用户的行为数据分析

plt.figure(figsize=(15,18),dpi=80)

plt.subplot(211)

plt.plot(pv_daily_hour[‘hour’],pv_daily_hour[‘pv’],‘bo-’)

plt.title(“每小时PV”)

plt.savefig(“每小时PV.png”)

plt.xticks(np.arange(0, 24, step=1))

plt.xlim(data.index.values[0])

plt.figure(figsize=(15,18),dpi=80)

plt.subplot(212)

plt.plot(uv_daily_hour[‘hour’],uv_daily_hour[‘uv’],‘yo-’)

plt.title(“每小时UV”)

plt.savefig(“每小时UV.png”)

plt.xticks(np.arange(0, 24, step=1))

plt.xlim(data.index.values[0])

plt.show()

Python大数据-对淘宝用户的行为数据分析

  • 从早上5:00-10:00,18:00-21:00这两个时间段pv有较明显上升;uv从早上6:00-10:00有较明显增加,而后到21点uv保持稳定数量,然后开始下降;pv、uv变化符合大众工作作息时间,侧面证明数据是真是有效的。

2、不同购物行为在不同时间维度下的变化情况


plt.figure(figsize=(10, 4))

sns.lineplot(data=d_pv_h, lw=3)

plt.show()

Python大数据-对淘宝用户的行为数据分析

plt.figure(figsize=(10, 4))

sns.lineplot(data=d_pv_h.iloc[:, 1:], lw=3)

plt.show()

Python大数据-对淘宝用户的行为数据分析

虽然大体上各波动趋势相同,但是加购物车数远高于收藏数。

round(data[‘user_id’].shape[0]/data[‘user_id’].nunique(),2)

##=1225.69

round(data[‘user_id’].shape[0]/data[‘user_id’].nunique()/data[‘date’].nunique(),2)

##=39.54

分析期间,每个UV的平均PV量是1225.69,每个UV的平均访问深度是39.54

3 、用户转化行为漏斗模型分析


view = data.groupby([‘behavior_type’])[‘user_id’].count().reset_index().rename(columns={‘user_id’:‘pv’})

view.head

Python大数据-对淘宝用户的行为数据分析

其中

beihavior_type-1点击2收藏3加购物车4支付

#计算各个环节的流失率

print(“点击->加购物车流失率是:%d” % round((view[‘pv’][0]-view[‘pv’][2])*100/view[‘pv’][0],4) + ‘%’)

print(‘点击->收藏流失率是:%d’ % round((view[‘pv’][0]-view[‘pv’][1])*100/view[‘pv’][0],4) + ‘%’)

print(‘加购物车->支付的流失率是:%d’ % round((view[‘pv’][2]-view[‘pv’][3])*100/view[‘pv’][2],4) + ‘%’)

print(‘收藏->支付的流失率是:%d’ % round((view[‘pv’][1]-view[‘pv’][3])*100/view[‘pv’][1],4) + ‘%’)

Python大数据-对淘宝用户的行为数据分析

from pyecharts.charts import Funnel

attr = [‘点击’,‘收藏’,‘加购物车’,‘支付’]

image_data = [(attr[i],int(view[‘pv’][i])) for i in range(len(attr))]

print(image_data)

funnel = (Funnel().add(series_name=‘用户行为漏斗’, data_pair=image_data))

funnel.render_notebook()

Python大数据-对淘宝用户的行为数据分析

用户产生点击后可能进行的操作分别为:点击->加购物车、点击->收藏、加购物车->支付、收藏->支付,可以明显的看出用户的流失率比较大,根据用户购买途径计算出各个阶段用户流失率

Python大数据-对淘宝用户的行为数据分析

  • 从浏览——加入购物车/收藏——付款的转化率较低;可以看出浏览到加入购物车或者收藏这一环节的流失率较大,可能由于产品不符合消费者需求或者详情页面不友好等需要对其中原因进一步挖掘分析,查看独立访客情况。

独立访客漏斗模型计算

view = data.groupby([‘behavior_type’])[‘user_id’].apply(lambda x:x.drop_duplicates().count()).reset_index().rename(columns={‘user_id’:‘pv’})

view

    以上就是本篇文章【Python大数据-对淘宝用户的行为数据分析】的全部内容了,欢迎阅览 ! 文章地址:http://lianchengexpo.xrbh.cn/news/14576.html 
     资讯      企业新闻      行情      企业黄页      同类资讯      首页      网站地图      返回首页 迅博思语资讯移动站 http://lianchengexpo.xrbh.cn/mobile/ , 查看更多   
最新新闻
《中华上下五千年》之靖康之变
公元1125年,金太宗不顾盟约,攻打北宋。宋徽宗吓得把皇位传给太子,南下逃跑了。宋钦宗没有御敌的办法,也打算逃跑。刚正的大臣
app推广一手资源在哪里找?盘点2024年必备的八大app拉新渠道
地推社群是app推广一手资源的重要来源之一。作为较为经典、传统的地推资源对接渠道,地推社群中保留有不少优质的一手资源,因此
一分钟秒变midjourney关键词高手专家
在数字艺术的浪潮中,创作者们一直在寻求更加便捷、高效的方式来实现他们的创意愿望。指导AI绘画的指令,也被称为咒语,是这个创
五个边玩游戏还能边赚钱的项目,爱玩游戏的你不要错过!
一直会有很多人问,有没有可以用手机就能兼职赚钱的副业? 答案是肯定有,而且还非常多!其实赚钱这方面不管主业还是副业,最重
B站2019年度流行梗大赏,你都知道这是啥梗吗?
去年12月4日B站就发布了2019年年度弹幕——“AWSL”,这也是B站第三年进行年度弹幕盘点→今天(1月9日)哔哩哔哩(以下简称“B站
Keepalived是Linux下一个轻量级别的高可用解决方案,快来浅了解下
目录 企业应用中,单台服务器承担应用存在单点故障的危险单点故障一旦发生,企业服务将发生中断,造成极大的
NET:DNS:DNS 客户端解析超时
本文档介绍在 Windows DNS 客户端上配置一个或多个域名系统 (DNS) 服务器 IP 时存在的回退和超时行为。适用于:Windows 10 - 所
《天地至道-合气-全息哲学科学》36
三、行为与全息养生 行为就是人们的身份举动,反映人们的生活态度以及表达生活方式,概而言之即衣食住行。既然行为涉及生活方式
Python大数据-对淘宝用户的行为数据分析
一、项目背景 通过对2014年11月17日至2014年12月17日之间数据进行合并,获得该月用户的行为数据,数据量在一千万条
【韩网热议】留学生上北大到底算不算是学霸?韩国吃播网红学历姓氏引发热议
热帖评论:1. 무명의 더쿠 北大???抖抖2. 무명의 더쿠 你去跑了吗(译者注:“你吃饱了吗”的韩式发音)3. 무명의 더쿠 哦 我知
本企业新闻
推荐企业新闻

点击拨打: