python高潜用户分析

2023-10-08 10:50
文章标签 python 分析 用户 高潜

本文主要是介绍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 = Falseprint('文件读取完毕')
# 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 = Falseprint('文件读取完毕')
# 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")

源码如下:

这篇关于python高潜用户分析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/164759

相关文章

Python结合PyWebView库打造跨平台桌面应用

《Python结合PyWebView库打造跨平台桌面应用》随着Web技术的发展,将HTML/CSS/JavaScript与Python结合构建桌面应用成为可能,本文将系统讲解如何使用PyWebView... 目录一、技术原理与优势分析1.1 架构原理1.2 核心优势二、开发环境搭建2.1 安装依赖2.2 验

Java字符串操作技巧之语法、示例与应用场景分析

《Java字符串操作技巧之语法、示例与应用场景分析》在Java算法题和日常开发中,字符串处理是必备的核心技能,本文全面梳理Java中字符串的常用操作语法,结合代码示例、应用场景和避坑指南,可快速掌握字... 目录引言1. 基础操作1.1 创建字符串1.2 获取长度1.3 访问字符2. 字符串处理2.1 子字

一文详解如何在Python中从字符串中提取部分内容

《一文详解如何在Python中从字符串中提取部分内容》:本文主要介绍如何在Python中从字符串中提取部分内容的相关资料,包括使用正则表达式、Pyparsing库、AST(抽象语法树)、字符串操作... 目录前言解决方案方法一:使用正则表达式方法二:使用 Pyparsing方法三:使用 AST方法四:使用字

Python列表去重的4种核心方法与实战指南详解

《Python列表去重的4种核心方法与实战指南详解》在Python开发中,处理列表数据时经常需要去除重复元素,本文将详细介绍4种最实用的列表去重方法,有需要的小伙伴可以根据自己的需要进行选择... 目录方法1:集合(set)去重法(最快速)方法2:顺序遍历法(保持顺序)方法3:副本删除法(原地修改)方法4:

Python运行中频繁出现Restart提示的解决办法

《Python运行中频繁出现Restart提示的解决办法》在编程的世界里,遇到各种奇怪的问题是家常便饭,但是,当你的Python程序在运行过程中频繁出现“Restart”提示时,这可能不仅仅是令人头疼... 目录问题描述代码示例无限循环递归调用内存泄漏解决方案1. 检查代码逻辑无限循环递归调用内存泄漏2.

Python中判断对象是否为空的方法

《Python中判断对象是否为空的方法》在Python开发中,判断对象是否为“空”是高频操作,但看似简单的需求却暗藏玄机,从None到空容器,从零值到自定义对象的“假值”状态,不同场景下的“空”需要精... 目录一、python中的“空”值体系二、精准判定方法对比三、常见误区解析四、进阶处理技巧五、性能优化

使用Python构建一个Hexo博客发布工具

《使用Python构建一个Hexo博客发布工具》虽然Hexo的命令行工具非常强大,但对于日常的博客撰写和发布过程,我总觉得缺少一个直观的图形界面来简化操作,下面我们就来看看如何使用Python构建一个... 目录引言Hexo博客系统简介设计需求技术选择代码实现主框架界面设计核心功能实现1. 发布文章2. 加

python logging模块详解及其日志定时清理方式

《pythonlogging模块详解及其日志定时清理方式》:本文主要介绍pythonlogging模块详解及其日志定时清理方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录python logging模块及日志定时清理1.创建logger对象2.logging.basicCo

Python如何自动生成环境依赖包requirements

《Python如何自动生成环境依赖包requirements》:本文主要介绍Python如何自动生成环境依赖包requirements问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑... 目录生成当前 python 环境 安装的所有依赖包1、命令2、常见问题只生成当前 项目 的所有依赖包1、

如何将Python彻底卸载的三种方法

《如何将Python彻底卸载的三种方法》通常我们在一些软件的使用上有碰壁,第一反应就是卸载重装,所以有小伙伴就问我Python怎么卸载才能彻底卸载干净,今天这篇文章,小编就来教大家如何彻底卸载Pyth... 目录软件卸载①方法:②方法:③方法:清理相关文件夹软件卸载①方法:首先,在安装python时,下