PowerBI多元回归预测数据(Python)

前两天用PowerBI做了一个多元线性回归基于R语言的内容,点击《PowerBI多元回归预测数据(R语言)》可以查看,但是好像现在Python在人群中使用的更多,后面类似的涉及统计模型和机器学习的内容应该也会以Python为主,下面开始介绍一下Python和PowerBI一起实现多元线性回归并在PowerBI中进行筛选预测的方法,效果如下↓

从图中看应该还是清楚,过了两天我们又新增了p值检验参数,并且还新增了一个维度,就是推广投放费用的时候有三种投放规则(随机投放、手动精确投方和系统投放),这三个是定性变量,还需要独热编码转换成数值。新增了这个参数后,我们模型的匹配率更高了,之前R2是0.78左右,有了这个维度,R2直接上升到了0.88,几乎接近完美了。下面简单介绍一下实现方法。

数据还是之前的数据,只是又新增了一个费用投放方式的维度,如下↓

然后流程是PowerBI导入数据,这个数据很完整了,不需要清洗,不需要聚合,直接拿来使用就可以了,下面就是重点,如何调用Python来完成我们重点的参数计算。在Python里面有两种主流计算多元回归的方法,通过statsmodels里面OLS方法,或者调用SKlearn里面的线性回归方法都可以。我们这里使用的是第一种,因为第二种调用SKlearn的方法后面其他的机器学习模型应该会经常用到。

需要指出的是,我们有一个推广方式的字段是分类值,需要使用pd里面的get_dummies进行独热编码处理后才能使用。处理然后把数据合并在一起,加上一个1的常数列,就可以用一句很简单的语句建模拟合数据了,然后把拟合的参数转换成DataFrame格式,PowerBI就可以识别了,Python语句和结果如下↓

# 'dataset' holds the input data for this script
import pandas as pd
import statsmodels.api as sm
#数据预处理,分类数据编码(独热编码)
pro_t = pd.get_dummies(dataset['promotion_type'],prefix="pro_t")
df1 = pd.concat((dataset.iloc[:,2:6],pro_t), axis=1)
X = sm.add_constant(df1)
Y = dataset.iloc[:,1]
#建模。参数估计(回归系数、总体方差)
model = sm.OLS(Y, X)
results = model.fit()
p = results.params
p = pd.DataFrame(p.index,p.values).reset_index()

关键参数已经求出来了,下面就是按照之前的步骤把参数建好,然后把预测公式写好就行了。这里还是需要用到新建自定义参数4个。还有一点需要注意,因为推广方式我们采用独热编码处理成了三列,得到了三个值,但实际使用只能选择三个中的任意一个,这里我们通过IF语句和SELECTEDVALUE的方式做了一个选择器,整体的DAX语句和结果如下↓

截距 = CALCULATE(SUM([index]),'参数'[para]="const")
uv = CALCULATE(SUM([index]),'参数'[para]="uv")
promotion_exp = CALCULATE(SUM([index]),'参数'[para]="promotion_exp")
price_diff = CALCULATE(SUM([index]),'参数'[para]="price_diff")
service_score = CALCULATE(SUM([index]),'参数'[para]="service_score")
pro_t_radm = CALCULATE(SUM([index]),'参数'[para]="pro_t_radm")
pro_t_sys = CALCULATE(SUM([index]),'参数'[para]="pro_t_sys")
pro_t_cus = CALCULATE(SUM([index]),'参数'[para]="pro_t_cus")

GMV预测 = [截距] + [uv]*[UV Value] + [promotion_exp]*[费用投入 Value] + [price_diff]*[价格降低 Value] + [service_score]*[服务评分 Value] + [推广选项]

推广选项 = 
IF(SELECTEDVALUE('推广方式'[e])="pro_t_cus",[pro_t_cus],
IF(SELECTEDVALUE('推广方式'[e])="pro_t_radm",[pro_t_radm],
IF(SELECTEDVALUE('推广方式'[e])="pro_t_sys",[pro_t_sys],
BLANK())))

看上去有点多,但大部分是重复的,只要思路到位了就很简单了,看看目前的效果↓

看上去已经有初步成效了,接下来就是在完善一下,多一点对模型效果评估的信息加进来,我们再之前R2和调整R2的基础上,还新增了一个P值,p值越小模型效果越好,我们这里得出来的p值是10E-159,几乎为0了,所有很不错,Python代码和结果如下↓

import pandas as pd
import statsmodels.api as sm
#数据预处理,分类数据编码(独热编码)
pro_t = pd.get_dummies(dataset['promotion_type'],prefix="pro_t")
df1 = pd.concat((dataset.iloc[:,2:6],pro_t), axis=1)
X = sm.add_constant(df1)
Y = dataset.iloc[:,1]
model = sm.OLS(Y, X)
results = model.fit()
R2 = results.rsquared
R2ajd = results.rsquared_adj
fp = results.f_pvalue #模型线性关系不成立的概率
r2 = pd.DataFrame(columns=['R2',"R2adj","fp"])
r2 = r2.append(pd.DataFrame({
        'R2':[R2],
        "R2adj":[R2ajd],
        "fp":[fp]
    }))

然后我们继续,再前面点预测的基础上,新增一个在95%置信区间上的区间预测。首先我们先求出置信区间上各个参数值,然后再代入PowerBI公式就可以了,Python代码如下↓

import pandas as pd
import statsmodels.api as sm
#数据预处理,分类数据编码(独热编码)
pro_t = pd.get_dummies(dataset['promotion_type'],prefix="pro_t")
df1 = pd.concat((dataset.iloc[:,2:6],pro_t), axis=1)
X = sm.add_constant(df1)
Y = dataset.iloc[:,1]
#建模。参数估计(回归系数、总体方差)
model = sm.OLS(Y, X)
results = model.fit()
p_conf_int = results.conf_int().reset_index()

DAX语句如下↓

low_截距 = CALCULATE(SUM([low]),'置信区间'[index]="const")
low_uv = CALCULATE(SUM([low]),'置信区间'[index]="uv")
low_promotion_exp = CALCULATE(SUM([low]),'置信区间'[index]="promotion_exp")
low_price_diff = CALCULATE(SUM([low]),'置信区间'[index]="price_diff")
low_service_score = CALCULATE(SUM([low]),'置信区间'[index]="service_score")
low_pro_t_radm = CALCULATE(SUM([low]),'置信区间'[index]="pro_t_radm")
low_pro_t_sys = CALCULATE(SUM([low]),'置信区间'[index]="pro_t_sys")
low_pro_t_cus = CALCULATE(SUM([low]),'置信区间'[index]="pro_t_cus")

height_截距 = CALCULATE(SUM([height]),'置信区间'[index]="const")
height_uv = CALCULATE(SUM([height]),'置信区间'[index]="uv")
height_promotion_exp = CALCULATE(SUM([height]),'置信区间'[index]="promotion_exp")
height_price_diff = CALCULATE(SUM([height]),'置信区间'[index]="price_diff")
height_service_score = CALCULATE(SUM([height]),'置信区间'[index]="service_score")
height_pro_t_radm = CALCULATE(SUM([height]),'置信区间'[index]="pro_t_radm")
height_pro_t_sys = CALCULATE(SUM([height]),'置信区间'[index]="pro_t_sys")
height_pro_t_cus = CALCULATE(SUM([height]),'置信区间'[index]="pro_t_cus")

GMV预测height = INT([height_截距] + [height_uv]*[UV Value] + [height_promotion_exp]*[费用投入 Value] + [height_price_diff]*[价格降低 Value] + [height_service_score]*[服务评分 Value] + [height推广选项])
GMV预测low = INT([截距] + [low_uv]*[UV Value] + [low_promotion_exp]*[费用投入 Value] + [low_price_diff]*[价格降低 Value] + [low_service_score]*[服务评分 Value] + [low推广选项])
GMV预测范围 = "["&[GMV预测low]&" - "&[GMV预测height]&"]"

到此,我们就完成了全部的流程,看看最后的效果↓

就结束了,下周有个内部的Excel基础培训,我这两天准备点资料,顺便简单分享一下,发出来参考。

End

◆ PowerBI_RFM客户关系模型
◆ PowerBI饼图、圈图、旭日图
Excel时间序列预测函数
◆ Python操作MySQL数据库
◆ Python企业微信机器人

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

推荐阅读更多精彩内容

  • 前几天写了一篇直接在PowerBI里面使用度量值做一元回归的内容,虽然灵活性很高,但是实际中对一个结果影响的因素是...
    Lin王发林阅读 412评论 0 0
  • 前面还写过一篇多元回归的内容,是通过在PowerQuery里面调用Python实现回归参数计算的,然后在Power...
    Lin王发林阅读 419评论 0 0
  • 使用了一段PowerBI的朋友应该对parameter这个可以做动态数字筛选的参数有一定了解,可以根据需求更灵活的...
    Lin王发林阅读 637评论 0 0
  • 现在形势趋于稳定了,SQL系列也差不多了,后面就根据情况加一些应用案例就行了。接下来终于可以开始很久以前就准备的P...
    Lin王发林阅读 2,040评论 0 1
  • 在管理咨询和商业分析中,矩阵分析是最常见的一种分析方法,比如波士顿矩阵、通用矩阵、安索夫矩阵等等。其基本思路就是根...
    Lin王发林阅读 304评论 0 0