基于RFM模型的用戶分類及精細化運營(附實例)

?一吓揪、RFM模型簡介

1亲怠、釋義

RFM模型是衡量客戶價值和客戶創(chuàng)利能力的重要工具和手段。在眾多的客戶關(guān)系管理(CRM)的分析模式中磺芭,RFM模型是被廣泛提到的赁炎。該機械模型通過一個客戶的近期購買行為、購買的總體頻率以及花了多少錢3項指標(biāo)來描述該客戶的價值狀況钾腺。

R:最近一次消費 (Recency):代表用戶距離當(dāng)前最后一次消費的時間

F:消費頻率 (Frequency):用戶在一段時間內(nèi)徙垫,對產(chǎn)品的消費頻次

M:消費金額 (Monetary):代表用戶的貢獻價值

image

一般情況下,我們將R放棒、F姻报、M分別分五個維度打分,通過歸一化打分之后间螟,把用戶所打分值與所有用戶的總分均值作高低比較吴旋,再將R损肛、F、M每個方向定義為:高荣瑟、低治拿,兩個方向,如此可將用戶分為222=8類笆焰,如下:

image

當(dāng)我們將客戶分類后劫谅,便可以針對性指定精細化運營策略,幫助大家了解完RFM模型后嚷掠,我將用一個實例具體展示操作流程捏检,以下實例以某玩家作品網(wǎng)站為例,爬取前十個網(wǎng)頁共240個玩家作品的昵稱不皆、編號贯城、點贊數(shù)、積分霹娄、上傳日期時間等信息進行分析能犯,具體流程如下:

1 數(shù)據(jù)爬取

2 數(shù)據(jù)清洗

3 數(shù)據(jù)分析

3.1 重新定義RFM

3.2 定義RFM打分標(biāo)準(zhǔn)

3.3 歸一化打分

3.4 計算RFM均值

3.5 用戶分類

3.6 統(tǒng)計與可視化

4 運營策略

1 數(shù)據(jù)爬取


import requests
from bs4 import BeautifulSoup
import numpy as np
import pandas as pd
import warnings
warnings.filterwarnings('ignore')
?
#獲取十個網(wǎng)頁網(wǎng)址
url_lst=[]
for i in range(1,11):
    urli='http://www.minicap.com/works?page='+str(i)
    url_lst.append(urli)
    
print(url_lst)
?
#獲取十個網(wǎng)頁共240個作品的網(wǎng)址
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條網(wǎng)址'%n)
        n+=1
print(word_lst)
?
#獲取240個作品的相關(guān)信息
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個網(wǎng)址的基本信息'%n)
        n+=1

2 數(shù)據(jù)清洗


#數(shù)據(jù)清洗
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)
?
#查看數(shù)據(jù)維度和結(jié)構(gòu)
print(df.dtypes)
print('-----------------')
print(df.info())
?
#修改數(shù)據(jù)類型
df['integral']=df['integral'].astype(int)
df['like_num']=df['like_num'].astype(int)
df['date']=pd.to_datetime(df['date'])
print(df.dtypes)
?
#數(shù)據(jù)保存
df.to_excel(r'C:\Users\Lenovo\Desktop\小瓶蓋數(shù)據(jù).xlsx')

3 數(shù)據(jù)分析

3.1 重新定義RFM

由于獲取的是作品相關(guān)信息(獲取信息有限),所以在此對RFM進行重新定義:

R:最近一次上傳作品日期據(jù)今天幾天犬耻;

F:作品數(shù)(用戶最近一段時間內(nèi)上傳作品的數(shù)量)悲雳;

M:點贊數(shù)(用戶最近一段時間內(nèi)上傳作品的點贊總數(shù))

3.2 定義RFM打分標(biāo)準(zhǔn)

image.png

3.3 歸一化打分

image.png

3.4 計算RFM均值

image.png

3.5 用戶分類

將3.3與3.4比較得出用戶分類

image.png

3.6 統(tǒng)計與可視化

image.png
image

4 運營策略


image.png

以上便是此次操作全過程,不當(dāng)之處香追,還請指正,謝謝坦胶!

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末透典,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子顿苇,更是在濱河造成了極大的恐慌峭咒,老刑警劉巖,帶你破解...
    沈念sama閱讀 212,542評論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件纪岁,死亡現(xiàn)場離奇詭異凑队,居然都是意外死亡,警方通過查閱死者的電腦和手機幔翰,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,596評論 3 385
  • 文/潘曉璐 我一進店門漩氨,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人遗增,你說我怎么就攤上這事叫惊。” “怎么了做修?”我有些...
    開封第一講書人閱讀 158,021評論 0 348
  • 文/不壞的土叔 我叫張陵霍狰,是天一觀的道長抡草。 經(jīng)常有香客問我,道長蔗坯,這世上最難降的妖魔是什么康震? 我笑而不...
    開封第一講書人閱讀 56,682評論 1 284
  • 正文 為了忘掉前任,我火速辦了婚禮宾濒,結(jié)果婚禮上腿短,老公的妹妹穿的比我還像新娘。我一直安慰自己鼎兽,他們只是感情好答姥,可當(dāng)我...
    茶點故事閱讀 65,792評論 6 386
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著谚咬,像睡著了一般鹦付。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上择卦,一...
    開封第一講書人閱讀 49,985評論 1 291
  • 那天敲长,我揣著相機與錄音,去河邊找鬼秉继。 笑死祈噪,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的尚辑。 我是一名探鬼主播辑鲤,決...
    沈念sama閱讀 39,107評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼杠茬!你這毒婦竟也來了月褥?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,845評論 0 268
  • 序言:老撾萬榮一對情侶失蹤瓢喉,失蹤者是張志新(化名)和其女友劉穎宁赤,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體栓票,經(jīng)...
    沈念sama閱讀 44,299評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡决左,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,612評論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了走贪。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片佛猛。...
    茶點故事閱讀 38,747評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖坠狡,靈堂內(nèi)的尸體忽然破棺而出挚躯,到底是詐尸還是另有隱情,我是刑警寧澤擦秽,帶...
    沈念sama閱讀 34,441評論 4 333
  • 正文 年R本政府宣布码荔,位于F島的核電站漩勤,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏缩搅。R本人自食惡果不足惜越败,卻給世界環(huán)境...
    茶點故事閱讀 40,072評論 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望硼瓣。 院中可真熱鬧究飞,春花似錦、人聲如沸堂鲤。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,828評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽瘟栖。三九已至葵擎,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間半哟,已是汗流浹背酬滤。 一陣腳步聲響...
    開封第一講書人閱讀 32,069評論 1 267
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留寓涨,地道東北人盯串。 一個月前我還...
    沈念sama閱讀 46,545評論 2 362
  • 正文 我出身青樓,卻偏偏與公主長得像戒良,于是被迫代替她去往敵國和親体捏。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,658評論 2 350

推薦閱讀更多精彩內(nèi)容