京公网安备 11010802034615号
经营许可证编号:京B2-20210330
作者:野水晶体
来源:livandata
看到这个题目,大家是否会有一些小小的想法?别闹了!笔者是一个正经人,讨论的也是一个有关python的技术问题,哈哈~
每个人的行为都是有迹可循的,这些蛛丝马迹可以作为预测的数据支持,有没有想过一个人什么时候住酒店能够被预测出来?笔者作为一个从事机器学习方面的程序员,对这一问题表示肯定,因为,如果不信就没有工作了。
笔者以为:所谓预测即为通过历史上遗留下来的蛛丝马迹:行为、订单甚至大厅门口的摄像头,判断某个人接下来的行为举动。这样的预测多少还是有些价值的,毕竟,人的想法是会通过行为表达出来,想法是渐变的,也就预示着行为存在一定的连续性。
试想一下,如果一个人或者一个公司能有客户在某个地方的消费记录,以及通过观察分析发现客户的基本特征,数据量足够大的情况下是否能够预测出客人什么时候入住酒店呢?我想结论大家都知道了~
作为一个旁观者和理论家(哈哈),我们来一起探讨一下,什么样的特征和模型能够预测出客户住酒店的时间?
有没有一点小小激动,毕竟预测是在不确定性中寻找肯定~
01、酒店预测的价值 Value
有谁会关心酒店的预测结果呢?
如果你想到的是情感问题,哈哈,我想该让你失望了,因为笔者是一个满心工作的狂人。姑且将上面的人群算作一个吧,还会有谁呢?
1) 心系万千客户的大老板们;
2) 将骄傲赋予代码的程序员们;
3) 天天接待客户的销售精英们;
4) 想尽奇招探索客户的运营大佬们;
……
预测的价值在于能够帮助决策者减少混乱,是否到店?什么时候到店?的基础上实现客群的细分并在细分客群的思路下挖掘客户更深入的价值。在大数据领域中,预测将会是大数据的核心价值。
02、预测的思路 Thoughts
什么样的客户会进入到我们的酒店呢?
客户什么样的行为预示着要来酒店了呢?
我想这是酒店运营或老板最关心的问题吧?
正如上文所言,一个好的预测是需要对历史数据进行充分的解读,然后基于数据特性进行模型的构建,最终得到预测结果。
因此,我们需要分析一下什么样的情况下才会发生酒店入住行为,以及入住时间受什么因素影响?
对于酒店的入住,往往受较多方面的影响:出差、旅游、走亲访友……
入住时间呢?影响入住时间的因素往往较为宽泛,比如:春夏秋冬季节时令、酒店所处城市、酒店附近交通的便利程度、天气情况等等……
再结合酒店的定位、客户的年龄、性别,以及从着装、谈吐定位出的薪资水平、社会阶层等几乎可以勾勒出一个较为完整的特征集合了。
基本特征如下:
其中有些特征是需要进行线下录入,或者逻辑推理完成,比如:入住目的,在华为公司附近的酒店,见到来自上海的华为员工,工作日独身一人办理入住,完全有理由相信,他来是出差的~
特征整理好之后我们就需要对模型有一个预判了:
首先这是一个连续值预测模型,我们姑且把时间转化成连续值,预测到月日粒度就可以了。
常见的连续值预测模型有如下几个:
1) 线性回归;
4) ARIMA等时间序列模型;
每一种模型都会有他的优势和缺点,比如:线性回归预测方便简单,但是较难解决自相关的问题;神经网络能较好的拟合高维特性但是解释性较差;ARIMA需要较强的融合时间因素等等。他们的优缺点包括但不限于这些描述,有兴趣的读者可以深入了解一下。
本文笔者采用的是决策树融合线性回归GBDT+Ridge的建模方式,这一方式主要是受到GBDT+LR模型的启发,facebook构建的GBDT+LR融合模型在点击率预测中效果显著,曾一度在各个公司中应用,但是在连续值预测中多少会有一些不足,毕竟LR模型是一个用线性回归实现的分类模型,曲线的调整会影响预测的效果。
GBDT+Ridge融合模型用岭回归替换掉了LR的部分,对应功能上Ridge更适合进行连续值的预测。另外,Ridge可以通过添加约束条件以及惩罚系数,限定预测范围和解决多重共线性的问题,预测结果调整上具有一定程度的灵活性;
GBDT本身在决策树方面有较好的名气:
1) 其对特征值有较好的容忍性,数据有空值、异常值等情况下都可以有效运行;
2) 对较高维度的特征融合效果也较为突出,因为树的特性,GBDT能够有效的探索高维的特征特性,每一个树状分支都是对多个特征的高维度融合;
3) 由于其boosting的设计思路,不停的迭代优化能够迅速提升模型的准确性;
所以GBDT从一出生就是明星算法。
但是其本身也存在一定的缺点:
1) 树的每个分支都有一个维度相乘的效果,每个维度的变化都会引发整体的变化,因此其灵敏度较高,容易过拟合;
2) 无法较好的用在连续值预测上,GBDT本质上还是一个分类算法;
而Ridge刚好弥补了这一问题,线性回归Ridge中各个特征值是相加的,单个特征的变化对整体的影响较小,同时Ridge本身就是用来进行连续值预测的,又较好的解决了多重共线性的问题。
基于上面的考虑,笔者对两个模型进行了融合,让有情人终成眷属。
03、预测的实现逻辑 Logic
模型的预测基本上遵循数据建模的常规套路,我们借这个机会将流程进行一些梳理:
1) 特征清洗:数据的离散化、归一化,缺失值填充,one_hot/WOE变化等;
2) 特征降维:降维主要有两方面原因,其一是维度之间有一些共线性,我们在训练过程中需要把对y值影响不大或者x之间相互影响的特征剔除掉;其二是当我们用one_hot进行向量化变化之后,往往存在梯度爆炸等问题,为了解决这一问题,我们经常用到的方法有:主成分分析、因子分析、决策树筛选、相关系数计算、embedding、稀疏自编码等;
3) 切分训练集和测试集:在训练集和测试集的切分中常用的方法有两个:其一是按照一定比例随机提取,比如:随机2:8分,80%数据做训练集,20%数据做测试集,这一方法简单高效,但是训练的准确性较低;其二:K-fold切分,将数据集拆分成测试集和训练集之后,对训练集进行K折拆分,循环训练,循环验证,可以有效防止过拟合的现象;
4) 构建模型:模型的构建正如上文提到的,我们使用的GBDT+Ridge融合模型,在建模过程中,需要格外小心模型的输入和输出数据格式,通常我们会把融合模型整合成一个函数,那么对应的参数作为输入数据就需要做好格式对照;
5) 模型保存/使用:训练好的模型需要进行保存固话,这样可以避免下次使用模型的时候重新训练,毕竟一次模型的训练需要较长的时间,固话模型的一些常用方法有:pickle、joblib等,对于一些深度学习的模型存在各自的方法,比如keras中的model.save();模型使用时也有对应的方法,比如:joblib和pickle中的loads函数,可以有效的还原训练好的模型,直接使用到生产环境中。
6) 训练结果验证:训练结果需要进行比较才能知道好坏,我们通常会选择多个模型,融合之后通过一定的指标进行比较,常用的比较指标有:F-score、AUC、ROC曲线等。
上面即为构建模型的常规思路,在这样的思路下,我们实现了酒店入住时间的预测,小小的满足了一下宅男的臆想,看到这里估计会被我的技术折服吧,哈哈,小小调侃一下~
下面是作为程序员的必备课了,上代码~
04、预测代码 Code
预测代码主要是基于下面的思路进行构建的:
1)数据结构为:
2)文件结构为:
3) 对应代码为:
首先需要对代码进行特征处理;
……
grd = GradientBoostingClassifier(n_estimators=60)# 调用one-hot编码。grd_enc = OneHotEncoder()# 调用LR分类模型。# grd_lm = LogisticRegression()grd_lm = RidgeCV(alphas=[0.1, 1.0, 10.0])# 使用X_train训练GBDT模型,后面用此模型构造特征grd.fit(train_X, train_y)# fit one-hot编码器grd_enc.fit(grd.apply(train_X)[:, :, 0])# 使用训练好的GBDT模型构建特征,然后将特征经过one-hot编码作为新的特征输入到LR模型训练。# clf = grd_lm.fit(grd_enc.transform(grd.apply(X_train_lr)[:, :, 0]), y_train_lr)clf = grd_lm.fit(grd_enc.transform(grd.apply(X_train_lr)[:, :, 0]), y_train_lr) # 线性回归建模# 用训练好的LR模型对X_test做预测y_pred_grd_lm = grd_lm.predict(grd_enc.transform(grd.apply(test_X)[:, :, 0]))
……
其次需要进行数据汇总;
……
data_s = pd.merge(data_1_4, data_2_2, on='id', how='inner')data_s = pd.merge(data_s, data_3_4, on='id', how='inner')data_s = pd.merge(data_s, data_4_2, on='id', how='inner').drop_duplicates().reset_index()data_s = data_s.filter(regex="[^'index']")data_s.to_csv('data_s.csv', encoding="utf_8_sig")
……
最后就是验证和使用;
grd = GradientBoostingClassifier(n_estimators=60)# 调用one-hot编码。grd_enc = OneHotEncoder()# 调用LR分类模型。# grd_lm = LogisticRegression()grd_lm = RidgeCV(alphas=[0.1, 1.0, 10.0])# 使用X_train训练GBDT模型,后面用此模型构造特征grd.fit(train_X, train_y)# fit one-hot编码器grd_enc.fit(grd.apply(train_X)[:, :, 0])# 使用训练好的GBDT模型构建特征,然后将特征经过one-hot编码作为新的特征输入到LR模型训练。# clf = grd_lm.fit(grd_enc.transform(grd.apply(X_train_lr)[:, :, 0]), y_train_lr)clf = grd_lm.fit(grd_enc.transform(grd.apply(X_train_lr)[:, :, 0]), y_train_lr) # 线性回归建模# 用训练好的LR模型对X_test做预测y_pred_grd_lm = grd_lm.predict(grd_enc.transform(grd.apply(test_X)[:, :, 0]))
……
数据分析咨询请扫描二维码
若不方便扫码,搜微信号:CDAshujufenxi
【核心关键词】大数据、零售商、消费者、供应链、运营、企业、产品、客户、数据模型、大数据平台、数据开发、系统运维、业务逻 ...
2026-06-26在物流配送、供应链履约、终端供货等业务场景中,送货率是衡量企业履约能力、服务质量、供应链稳定性的核心业务指标,直接关联客 ...
2026-06-26 很多数据分析师精通描述性统计,能熟练计算均值、中位数、标准差,但当被问到“用500个样本如何推断10万用户的真实满意度” ...
2026-06-26在数字化管理与数据化运营体系中,指标是连接原始数据与业务决策的核心载体。零散的原始数据只是无意义的数值堆砌,无法直接反映 ...
2026-06-25在Excel数据汇总、财务统计、业务复盘等日常办公场景中,经常需要完成逐行相乘、整体汇总求和的计算需求,最典型的场景就是:单 ...
2026-06-25 很多数据分析师沉迷于复杂的机器学习算法,却忽略了数据分析最基础也最核心的能力——描述性统计。事实上,80%的商业分析问 ...
2026-06-25【核心关键词】主数据、资产、供应商、现金流、企业、精细化、集团、数字化、中国、数据质量、数据管理、经营管理、地产行业、 ...
2026-06-24在数据分析、假设检验、AB测试、学术研究等统计场景中,显著水平(α)与P值(P-value)是判断统计结果是否具有统计学意义的两个 ...
2026-06-24小李刚入职了一家互联网公司的运营部门。第一次参加业务复盘会,运营主管问了一个看似简单的问题:“这个月新用户留存率下降了5 ...
2026-06-24在数字化转型全面渗透的产业背景下,数据分析已成为互联网、金融、零售、制造等几乎所有行业的核心岗位能力。很多初学者对数据分 ...
2026-06-23在企业并购、股权定价、投融资评估、资产核算等资本市场核心场景中,市场法是应用最广泛、市场认可度最高的企业价值评估方法。传 ...
2026-06-23 许多数据分析师精通Excel函数和SQL查询,但当面对一张上万行的销售明细表,要快速回答“哪个地区销量最高”“哪款产品增长最 ...
2026-06-23【核心关键词】运营、证书、金融、客户、产品、软件、销售额、量化、科技、数据分析、金融行业、证券类软件、业务流程、金融机 ...
2026-06-22在企业方案选型、产品迭代评审、供应商筛选、运营效果复盘等决策场景中,单一指标的优劣判断往往无法支撑科学决策。一套转化效果 ...
2026-06-22 很多数据分析师掌握了Excel函数、会写SQL查询,但当被问到“数据从哪里来”“数据加工有哪些步骤”“如何使用分析工具连接数 ...
2026-06-22【核心关键词】软件、洞察力、大数据、产品、经验、硬件、流量、创新、决策、数据安全、网络安全、数据分析、决策制定、数据挖 ...
2026-06-18在方案选型、效果复盘、产品评估、供应商筛选等各类业务决策场景中,仅凭单一指标下结论往往会陷入 “以偏概全” 的误区。多维度 ...
2026-06-18 很多数据分析师精通Excel单元格操作,但当被问到“表结构数据的基本处理单位是什么”“字段和记录的本质区别”“为什么表结 ...
2026-06-18在数据分析、用户运营与业务增长的工作体系中,漏斗拆解是最基础也最高频的问题定位方法。很多业务场景下,我们只能看到最终的转 ...
2026-06-17在数据库开发、数据清洗与报表统计场景中,数值类型转换为日期是高频刚需操作。业务系统常以 Unix 时间戳、整型日期(如20240617 ...
2026-06-17