【Python机器学习】数据可视化讲解及性别、周末与购物间可视化实战(超详细 附源码)

简介: 【Python机器学习】数据可视化讲解及性别、周末与购物间可视化实战(超详细 附源码)

需要源码和数据集请点赞关注收藏后评论区留言私信~~~

数据可视化

数据可视化通过直观的方式增加对数据的理解,帮助提取有用特征。

1.特征取值分布

特征的取值分布情况可以为分析特征提供重要信息。一般采用直方图和饼图来可视化取值分布。Python扩展库Matplotlib提供了多种画图方法。

2.离散型特征与离散型标签的关系

样本特征的值与该样本的标签的关系,是机器学习最为关心的事情。通过可视化,可以直观地展现标签值随某特征取值的变化而变化的情况。

3.连续型特征与离散型标签的关系

观察连续型特征与离散型标签的关系,常用盒图(Box plots)。

对于单个变量,盒图描述的是其分布的四分位图:上边缘 上四分位数 中位数 下四分位数和下边缘,上边缘是最大数,上四分位数是由大到小排在四分之一的那个值,中位数是排在中间的那个数,下四分位数是排在四分之三的那个数,下边缘是最小数,单个变量的盒图便于观察变量值的分布中心 扩展和偏移,另外还可以发现离群的异常值的存在

4.离散型特征与连续型标签的关系

密度图(Density plots)也可用来可视化类似关系。 在密度图中,将每个离散的特征值画一条曲线,多条曲线放在一起进行比较,每个离散特征值的曲线的横坐标设为连续的标签值,纵坐标设为对应标签纸的密度

5.连续型特征与连续型标签的关系

连续型特征与连续型标签的关系是常用的画图方式,即将输入、输出值对应在平面上作点,可采用matplotlib和pandas中的scatter()函数。

下面是部分绘图函数与其对应函数方法

可视化性别、周末与购物之间关系

可以采用马赛克图来可视化离散型特征值与离散型标签的关系

下面给出一个简单示例,其中可视化了性别与购物之间关系的可视化,以及周末与购物之间关系的可视化

部分数据如下 性别1男 0女 是否购物 1购物 0不购物

[2020, 11, 1, 1, 1],
               [2020, 11, 1, 0, 1],
               [2020, 11, 1, 0, 1],
               [2020, 11, 1, -1, 1],
               [2020, 11, 1, 1, 1],
               [2020, 11, 1, 0, 1],
               [2020, 11, 1, 0, 0],
               [2020, 11, 1, 0, 1],
               [2020, 11, 2, 1, 0],
               [2020, 11, 2, 1, 1],
              ],
               [2020, 11, 7, 0, 1],
               [2020, 11, 8, 1, 1],
               [2020, 11, 8, 0, 1],
               [2020, 11, 9, 0, 0],
               [2020, , 11, 1, -1],
               [2020, 11, 12, 0, 0]]

性别与购物关系的马赛克图如下

周末与购物之间关系如下

部分代码如下

import datetime # 导入datetime模块,该模块用来处理与日期和时间有关的计算
# 定义一个判断是否为周末的函数
def isweekend( date ): 
    theday = datetime.date( date[0], date[1], date[2] ) # 创建一个date对象
    if theday.isoweekday() in { 6, 7 }: # 如果date是周末则返回1,否则返回0
        return 1
    else:
        return 0
# 是否周末的特征,性别,是否购物三项数据
train_set1 = []
for i in range(len(train_data)):
        weekend = isweekend(train_data[i][:3])
        train_set1.append( [weekend, train_data[i][3], train_data[i][4]] )
wk = df[0].astype('str').apply(lambda x: '周末' if x=='1' else '非周末')
man = df[1].astype('str').apply(lambda x: '男' if x=='1' else '女')
label = df[2].astype('str').apply(lambda x: '购物' if x=='1' else '不购物')
#print(label)
mosaic_data1 = pd.concat([man, label], axis=1)
#print(mosaic_data)
mosaic(data=mosaic_data1, index=[1, 2], gap=0.01, title=u'性别与购物的关系')

创作不易 觉得有帮助请点赞关注收藏~~~

相关文章
|
3月前
|
JSON 开发工具 git
基于Python和pygame的植物大战僵尸游戏设计源码
本项目是基于Python和pygame开发的植物大战僵尸游戏,包含125个文件,如PNG图像、Python源码等,提供丰富的游戏开发学习素材。游戏设计源码可从提供的链接下载。关键词:Python游戏开发、pygame、植物大战僵尸、源码分享。
|
3月前
|
机器学习/深度学习 数据采集 数据可视化
Python数据科学实战:从Pandas到机器学习
Python数据科学实战:从Pandas到机器学习
|
3月前
|
机器学习/深度学习 人工智能 算法
【手写数字识别】Python+深度学习+机器学习+人工智能+TensorFlow+算法模型
手写数字识别系统,使用Python作为主要开发语言,基于深度学习TensorFlow框架,搭建卷积神经网络算法。并通过对数据集进行训练,最后得到一个识别精度较高的模型。并基于Flask框架,开发网页端操作平台,实现用户上传一张图片识别其名称。
179 0
【手写数字识别】Python+深度学习+机器学习+人工智能+TensorFlow+算法模型
|
3月前
|
机器学习/深度学习 数据采集 人工智能
探索机器学习:从理论到Python代码实践
【10月更文挑战第36天】本文将深入浅出地介绍机器学习的基本概念、主要算法及其在Python中的实现。我们将通过实际案例,展示如何使用scikit-learn库进行数据预处理、模型选择和参数调优。无论你是初学者还是有一定基础的开发者,都能从中获得启发和实践指导。
88 2
|
3月前
|
机器学习/深度学习 数据可视化 数据处理
掌握Python数据科学基础——从数据处理到机器学习
掌握Python数据科学基础——从数据处理到机器学习
69 0
|
3月前
|
机器学习/深度学习 数据采集 人工智能
机器学习入门:Python与scikit-learn实战
机器学习入门:Python与scikit-learn实战
107 0
|
3月前
|
机器学习/深度学习 数据采集 数据挖掘
Python在数据科学中的应用:从数据处理到模型训练
Python在数据科学中的应用:从数据处理到模型训练
|
2月前
|
人工智能 数据可视化 数据挖掘
探索Python编程:从基础到高级
在这篇文章中,我们将一起深入探索Python编程的世界。无论你是初学者还是有经验的程序员,都可以从中获得新的知识和技能。我们将从Python的基础语法开始,然后逐步过渡到更复杂的主题,如面向对象编程、异常处理和模块使用。最后,我们将通过一些实际的代码示例,来展示如何应用这些知识解决实际问题。让我们一起开启Python编程的旅程吧!
|
2月前
|
存储 数据采集 人工智能
Python编程入门:从零基础到实战应用
本文是一篇面向初学者的Python编程教程,旨在帮助读者从零开始学习Python编程语言。文章首先介绍了Python的基本概念和特点,然后通过一个简单的例子展示了如何编写Python代码。接下来,文章详细介绍了Python的数据类型、变量、运算符、控制结构、函数等基本语法知识。最后,文章通过一个实战项目——制作一个简单的计算器程序,帮助读者巩固所学知识并提高编程技能。
|
2月前
|
Unix Linux 程序员
[oeasy]python053_学编程为什么从hello_world_开始
视频介绍了“Hello World”程序的由来及其在编程中的重要性。从贝尔实验室诞生的Unix系统和C语言说起,讲述了“Hello World”作为经典示例的起源和流传过程。文章还探讨了C语言对其他编程语言的影响,以及它在系统编程中的地位。最后总结了“Hello World”、print、小括号和双引号等编程概念的来源。
126 80

推荐镜像

更多