基于RFM模型的用户分类及精细化运营(附实例)

​一、RFM模型简介

1、释义

RFM模型是衡量客户价值和客户创利能力的重要工具和手段。在众多的客户关系管理(CRM)的分析模式中,RFM模型是被广泛提到的。该机械模型通过一个客户的近期购买行为、购买的总体频率以及花了多少钱3项指标来描述该客户的价值状况。

R:最近一次消费 (Recency):代表用户距离当前最后一次消费的时间

F:消费频率 (Frequency):用户在一段时间内,对产品的消费频次

M:消费金额 (Monetary):代表用户的贡献价值

image

一般情况下,我们将R、F、M分别分五个维度打分,通过归一化打分之后,把用户所打分值与所有用户的总分均值作高低比较,再将R、F、M每个方向定义为:高、低,两个方向,如此可将用户分为222=8类,如下:

image

当我们将客户分类后,便可以针对性指定精细化运营策略,帮助大家了解完RFM模型后,我将用一个实例具体展示操作流程,以下实例以某玩家作品网站为例,爬取前十个网页共240个玩家作品的昵称、编号、点赞数、积分、上传日期时间等信息进行分析,具体流程如下:

1 数据爬取

2 数据清洗

3 数据分析

3.1 重新定义RFM

3.2 定义RFM打分标准

3.3 归一化打分

3.4 计算RFM均值

3.5 用户分类

3.6 统计与可视化

4 运营策略

1 数据爬取


import requests
from bs4 import BeautifulSoup
import numpy as np
import pandas as pd
import warnings
warnings.filterwarnings('ignore')
​
#获取十个网页网址
url_lst=[]
for i in range(1,11):
    urli='http://www.minicap.com/works?page='+str(i)
    url_lst.append(urli)
    
print(url_lst)
​
#获取十个网页共240个作品的网址
word_lst = []
n = 1
for url in url_lst:
    ri = requests.get(url)
    soupi = BeautifulSoup(ri.text,'lxml')
    info=soupi.find('div',class_='list_det').find('ul').find_all('li',class_='zp_list')
    for i in info:
        urli=' http://www.minicap.com'+i.find('a')['href']
        word_lst.append(urli)
        print('成功获取第%i条网址'%n)
        n+=1
print(word_lst)
​
#获取240个作品的相关信息
def get_data(url):
    
    ri=requests.get(url=url)
    soupi=BeautifulSoup(ri.text,'lxml')
    dic = {}
    dic['num']=soupi.find('div',class_='news_l news_det_l').find('div',class_='det_cont sw').find('div',class_='det_fx').find('div',class_='fxr').find('div',class_='det').find('p',class_='p1 dls').text[3:]
    dic['author']=soupi.find('div',class_='news_l news_det_l').find('div',class_='det_cont sw').find('div',class_='det_fx').find('div',class_='fxr').find('div',class_='det').find('p',class_='p2 dls').text.split(' ')[0][3:]
    info=soupi.find('div',class_='news_l news_det_l').find('div',class_='det_cont sw').find('div',class_='det_fx').find('div',class_='fxr').find('div',class_='det').find('p',class_='p3 dls').text.split(' ')
    for i in info[:]:
        if ''in info:
            info.remove('')
        if '\n' in info:
            info.remove('\n')
    dic['date']=info[0]
    dic['time']=info[1]
    dic['integral']=soupi.find('div',class_='news_l news_det_l').find('div',class_='det_cont sw').find('div',class_='det_fx').find('div',class_='fx').find('div',class_='ndjj').find('span',class_='jj').text.replace(' ','')[3:]
    dic['like_num']=soupi.find('div',class_='news_l news_det_l').find('div',class_='det_cont sw').find('div',class_='det_fx').find('div',class_='fx').find('div',class_='ndjj').find('div',class_='dz_box').find('span',class_='dz_num').text
    return dic
    
info_list = []
n=1
for url in word_lst:
        info_list.append(get_data(url))
        print('成功获取第%i个网址的基本信息'%n)
        n+=1

2 数据清洗


#数据清洗
df=pd.DataFrame(info_list)
for i in range(len(df)):
    df['author'][i]=df['author'][i].split('\n')[0]
    df['like_num'][i]=df['like_num'][i].split('\n')[1]
print(df)
​
#查看数据维度和结构
print(df.dtypes)
print('-----------------')
print(df.info())
​
#修改数据类型
df['integral']=df['integral'].astype(int)
df['like_num']=df['like_num'].astype(int)
df['date']=pd.to_datetime(df['date'])
print(df.dtypes)
​
#数据保存
df.to_excel(r'C:\Users\Lenovo\Desktop\小瓶盖数据.xlsx')

3 数据分析

3.1 重新定义RFM

由于获取的是作品相关信息(获取信息有限),所以在此对RFM进行重新定义:

R:最近一次上传作品日期据今天几天;

F:作品数(用户最近一段时间内上传作品的数量);

M:点赞数(用户最近一段时间内上传作品的点赞总数)

3.2 定义RFM打分标准

image.png

3.3 归一化打分

image.png

3.4 计算RFM均值

image.png

3.5 用户分类

将3.3与3.4比较得出用户分类

image.png

3.6 统计与可视化

image.png
image

4 运营策略


image.png

以上便是此次操作全过程,不当之处,还请指正,谢谢!

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 220,002评论 6 509
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,777评论 3 396
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 166,341评论 0 357
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 59,085评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 68,110评论 6 395
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,868评论 1 308
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,528评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,422评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,938评论 1 319
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,067评论 3 340
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,199评论 1 352
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,877评论 5 347
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,540评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,079评论 0 23
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,192评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,514评论 3 375
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,190评论 2 357

推荐阅读更多精彩内容