机器学习:基于逻辑回归对超市销售活动预测分析
创始人
2025-05-31 06:43:48
0

在这里插入图片描述

系列文章目录

作者:i阿极

作者简介:Python领域新星作者:博主个人首页

😊😊😊如果觉得文章不错或能帮助到你学习,可以点赞👍收藏📁评论📒+关注哦!👍👍👍

📜📜📜如果有小伙伴需要数据集和学习交流,文章下方有交流学习区!一起学习进步!💪


订阅专栏案例:机器学习
机器学习:基于逻辑回归对某银行客户违约预测分析
机器学习:学习k-近邻(KNN)模型建立、使用和评价
机器学习:基于支持向量机(SVM)进行人脸识别预测
决策树算法分析天气、周末和促销活动对销量的影响
机器学习:线性回归分析女性身高与体重之间的关系
机器学习:基于主成分分析(PCA)对数据降维
机器学习:基于朴素贝叶斯对花瓣花萼的宽度和长度分类预测
机器学习:学习KMeans算法,了解模型创建、使用模型及模型评价
机器学习:基于神经网络对用户评论情感分析预测
机器学习:朴素贝叶斯模型算法原理(含实战案例)
机器学习:逻辑回归模型算法原理(附案例实战)
机器学习:基于逻辑回归对优惠券使用情况预测分析

文章目录

  • 系列文章目录
  • 1、实验背景
  • 2、实验数据说明
  • 3、实验环境
  • 4、实验内容
  • 5、实验步骤
    • 5.1导入数据
    • 5.2数据探索
    • 5.3处理非数值型变量
    • 5.4构造模型


1、实验背景

一家超级市场正在计划年终促销。他们想推出一个新的优惠——黄金会员资格,所有购买的产品都有20%的折扣,只需499美元,其他日子里是999美元。该优惠政策将只对现有客户有效,目前他们正计划通过电话进行宣传。
管理层认为,降低活动成本的最好方法是建立一个预测模型,首先将可能购买该优惠的客户进行分类。

2、实验数据说明

数据信息是在去年的活动中收集的,以下为数据描述:

字段说明
Id每个客户的独特ID
Year_Birth客户的年龄
Education顾客的教育水平
Marital_Status客户的婚姻状况
Income客户的家庭年收入
Kidhome客户家庭中小孩的数量
Teenhome客户家庭中的青少年人数
Dt_Customer客户在公司注册的日期
Recency自上次购买以来的天数
MntWines在过去的两年中,购买葡萄酒产品的金额
MntFruits在过去的2年里,购买水果产品的消费金额
MntMeatProducts在过去的两年中,花在肉类产品上的金额
MntFishProducts在过去的两年中,花在鱼类产品上的金额
MntSweetProducts在过去两年中,花在甜食产品上的金额
MntGoldProds在过去的两年中,购买黄金产品的消费金额
NumDealsPurchases使用折扣购买的数量
NumWebPurchases通过公司网站购买的数量
NumCatalogPurchases使用目录购买的数量(购买货物通过邮件发送)。
NumStorePurchases直接在商店购买的数量
NumWebVisitsMonth上个月访问公司网站的次数
Response目标变量 - 如果客户在上一次活动中接受了报价,则为1,否则为0
Complain如果客户在过去两年中投诉,则为1

3、实验环境

Python 3.9

Anaconda

Jupyter Notebook

4、实验内容

使用逻辑回归对超市销售活动预测分析

5、实验步骤

5.1导入数据

import pandas as pd
import numpy as np
data = pd.read_csv("/home/mw/superstore_data.csv")
data.head()

在这里插入图片描述

5.2数据探索

查看数据数量

data.shape

在这里插入图片描述

有2240行,22个特征值

查看基本信息

data.info()

在这里插入图片描述

发现Income列有缺失值,接下来需要对缺失值进行处理

观察Income列缺失的行

income_missing = data[data.Income.isnull()]
income_missing

在这里插入图片描述

从他们的Year_Birth中发现,很多都是1960年之前的人,很有可能退休了(2023-65=1958)

before = income_missing[income_missing.Year_Birth < 1961]
after = income_missing[income_missing.Year_Birth > 1961]
import matplotlib.pyplot as plt
plt.bar(['before 1961','after 1961'],[len(before),len(after)])
plt.show()

在这里插入图片描述

对于可能退休的人(小于1961)我们用0填充,其他的用平均值

data.loc[(data['Year_Birth'] < 1961) & (data['Income'].isnull())] =data.loc[(data['Year_Birth'] < 1961) & (data['Income'].isnull())].fillna(0)
data.Income = data.Income.fillna(data.Income.mean())
data.isnull().sum()

在这里插入图片描述

对于可能退休的人(小于1961)我们用0填充,其他的用平均值,已经没有缺失值。

5.3处理非数值型变量

查看类型为object的列

non_num_cols = [cols for cols in data.columns if data[cols].dtype == 'object']
non_num_cols

在这里插入图片描述

首先我们将Dt_Customer转化为日期格式

data['Dt_Customer'] = pd.to_datetime(data['Dt_Customer'])

处理类别变量,先来看看有几种类别

data.Education.value_counts()

在这里插入图片描述

data.Marital_Status.value_counts()

在这里插入图片描述

因为alone、YOLO、Abusurd样本数很少,所以本次分析将 alone、YOLO、Abusurd 统一归为 Single。

data.Marital_Status = data.Marital_Status.replace(['Alone','YOLO','Absurd'],'Single')
data.Marital_Status.value_counts()

在这里插入图片描述


Marital_Status = pd.get_dummies(data.Marital_Status,prefix='Marital_Status')
data = data.drop('Marital_Status',axis=1).join(Marital_Status)

同理应用于教育状况

Education = pd.get_dummies(data.Education,prefix='Education')
data = data.drop('Education',axis=1).join(Education)
data

在这里插入图片描述

再来看看处理之后的特征值

data.info()

在这里插入图片描述

5.4构造模型

划分训练集和测试集

from sklearn.model_selection import train_test_split
y = data.Response  #目标变量
X = data.drop('Response',axis=1)
train_x,val_x,train_y,val_y = train_test_split(X,y,train_size=0.8,test_size=0.2,random_state=0)

用统计的方法看看相关性

cor = data.corr()
features = cor[(cor['Response'] < -0.1) | (cor['Response'] > 0.1)] .index.drop('Response')

模型搭建

from sklearn.linear_model import LogisticRegression
lr = LogisticRegression()
lr.fit(train_x[features],train_y)

验证

prey = lr.predict(val_x[features])
from sklearn.metrics import accuracy_score
accuracy_score(val_y,prey)

在这里插入图片描述
开始预测

predictions = lr.predict(data[features])
results = pd.DataFrame(data={'Id':data.Id,'Response':predictions})
results[:15]

在这里插入图片描述


📢文章下方有交流学习区!一起学习进步!💪💪💪
📢创作不易,如果觉得文章不错,可以点赞👍收藏📁评论📒
📢你的支持和鼓励是我创作的动力❗❗❗

相关内容

热门资讯

国资委谈央企重组:减少行业内卷 关于央企重组最新动向,今天(1月28日),国务院国资委企业改革局局长林庆苗在国新办发布会上透露,下一...
想“金蝉脱壳”卖身美国?中国养... 吃尽中国红利,却卸磨杀驴卖身美国,商务部摁死的AI白眼狼一点都不冤 蝴蝶效应科技一家靠中国土壤扶植...
遭商誉反噬!电魂网络迎上市首亏... 深圳商报·读创客户端记者 陈琳琳 2026年1月28日,电魂网络披露《股东及董事、高管减持股份结果公...
一度突破5300美元/盎司!现... 本报(chinatimes.net.cn)记者周梦婷 北京报道 国际现货黄金价格再攀新高。1月28日...
连续三年破万亿 深圳发布未来三... 来源:21世纪经济报道 21世纪经济报道记者李金萍 深圳报道 深圳稳坐“万亿消费之城”。2025年,...
超500家A股公司年报预亏 5... 当前正值上市公司年报预告披露期,不同于以往的绩优股抢先发布业绩,今年财报季里,一批亏损公司正在密集“...
马斯克突然变卦!SpaceX准... 王爷说财经讯: 史上最大IPO来袭! 你敢信吗?那个曾经发誓“绝不上市”、把季度财报视为“地狱之火”...
两家上市公司同时公告将2025... 来源:会计雅苑 公司原审计机构立信所因审计工作人员变动和整体工作安排等综合原因, 预计无法为公司提...
2026年深圳首家A股上市企业... 深圳商报·读创客户端记者 吴素红 李丹 1月28日,深圳市恒运昌真空技术股份有限公司在上海证券交易所...
【2026最新】现货黄金交易十... 在2026年全球经济错综复杂的背景下,避险情绪再度升温,现货黄金(伦敦金)凭借其高流动性和双向交易机...
原创 2... 你或许从未留意过车灯。 汽车产业卷到白热化的今天,连最不起眼的车灯,都成了兵家必争的黄金赛道,甚至开...
原创 白... 最近的白银价格大家看了吗? 现货白银的价格已经突破了100美元一盎司了,这个价格简直太离谱了。 上个...
传感器技术如何赋能智慧医疗?(... 编者按:传感器作为“信息时代的神经末梢”,已渗透到社会经济的每一个关键领域。2025年10月以来,《...
资源板块成“香饽饽”!成交额占... 财联社1月28日讯(编辑 梓隆),今日(1月28日),资源类板块成为市场关注焦点,其中,有色金属、石...
我国公募基金总规模逼近38万亿 1月28日,中基协发布的公募基金市场数据显示,截至2025年12月底,我国境内公募基金管理机构共16...
二度折戟!阳光诺和12亿关联收... (图片来源:视觉中国) 蓝鲸新闻1月28日讯(记者 邵雨婷)1月27日晚间,阳光诺和(688621....
泰国新出黄金交易限制措施 泰国皇家公报公布的新规规定,过去5年间年均黄金交易额达到或超过100亿泰铢(约合3.23亿美元)的黄...
SpaceX估值1.5万亿背后... 当特斯拉股价还在震荡时,埃隆·马斯克又给资本市场投下一枚"星际炸弹"——SpaceX计划于6月IPO...