【大数据】—二手车用户数据可视化分析案例

项目背景

在当今的大数据时代,数据可视化扮演着至关重要的角色。随着信息的爆炸式增长,我们面临着前所未有的数据挑战。这些数据可能来自社交媒体、商业交易、科学研究、医疗记录等各个领域,它们庞大而复杂,难以通过传统的数据处理和分析手段进行有效解读。正是在这样的背景下,数据可视化技术应运而生,以其直观、形象、易于理解的特点,成为连接数据与洞察的桥梁。数据可视化通过将抽象的数据转化为图表、图像等视觉元素,能够迅速揭示数据中的模式、趋势和关联,帮助人们快速理解复杂数据背后的含义。无论是数据分析师、商业决策者还是普通用户,都能够通过数据可视化工具轻松探索数据,发现新的见解,从而做出更明智的决策。

因此,在大数据时代,数据可视化技术的重要性不言而喻。它不仅是数据分析的重要工具,更是连接数据与洞察、促进跨领域合作的桥梁。随着技术的不断进步和应用场景的不断拓展,数据可视化将在未来发挥更加重要的作用,为我们揭示更多未知的数据奥秘。

本文以二手车市场数据给大家展示数据可视化的其中一种好看的方法(数据集已绑定可免费下载)。

数据集介绍

数据集来源于Kaggle,原始数据集为美国二手车市场用户数据,共有7906条,18个变量,各变量含义如下:

Sales_ID(销售ID)
name(二手车名称)
year(购车年份)
selling_price(二手车当前销售价格)
km_driven(总行驶公里数)
Region(使用地区)
State or Province(使用的州或省)
City(使用城市)
fuel(燃料类型)
seller_type(谁在出售汽车)
transmission(汽车的变速器类型)
owner(业主类型)
mileage(汽车行驶里程)
engine(发动机功率)
Max_power(最大功率)
torque(转矩)
seats(座位数)
sold(二手车是否售出)

可视化方法介绍

读入数据:

import pandas as pd
import matplotlib.pyplot as plt
import seaborn as sns
import plotly.express as px
from plotly.offline import iplot 
import warnings
warnings.filterwarnings('ignore')
plt.rcParams ['font.sans-serif'] ='SimHei'      #显示中文
plt.rcParams ['axes.unicode_minus']=False       #显示负号 
df = pd.read_csv("UserCarData.csv")
df.head()

在这里插入图片描述
图没有截完!时间有限,下面我主要给大家科谱图形相关内容,别的就不作讲解,截图展示就行。

在这里插入图片描述
在这里插入图片描述

# 二手车名称分析
print(f"Most Used Sold Car '{df['name'].value_counts().idxmax()}'")
print(f"Lowest Used Car Sold '{df['name'].value_counts().idxmin()}'")
# 使用plotly的express模块来绘制前20个最常被售出的二手车的柱状图   
iplot(px.bar(  
    df['name'].value_counts()[:20],  # 使用前20个最常出现的二手车名称及其计数  
    labels={'value':'数量', 'name':'车名'},  # 设置图表的标签  
    color=df['name'].value_counts()[:20].index,  # 设置每个柱子的颜色为其对应的二手车名称  
    text_auto=True,  # 自动将计数值添加到柱子上  
    title='二手车销量Top20'  # 设置图表的标题  
))  

在这里插入图片描述

# 使用plotly的express模块来绘制前20个最常被售出的二手车年份的柱状图  
# 注意:这里先对计数进行排序,确保年份是按从高到低的顺序显示  
# 使用sort_index(ascending=False)确保年份是降序排列  
iplot(px.bar(  
    df['year'].value_counts()[:20].sort_index(ascending=False),  # 取前20个最常出现的年份并降序排序  
    labels={'value':'数量', 'year':'年份'},  # 设置图表的标签  
    color_discrete_sequence=['#c72320'],  # 设置所有柱子的颜色为指定的红色  
    text_auto=True,  # 自动将计数值添加到柱子上  
    title='二手车出售年份柱状图'  # 设置图表的标题  
).update_xaxes(type=('category'))  # 将x轴设置为类别类型,确保年份按正确的顺序显示  
)  

在这里插入图片描述

柱状图(Bar Chart):

  • 定义:柱状图,也称为条形图,是一种用于展示离散数据分布情况的图形。它通过一系列垂直或水平的条形来表示不同类别的数据,每个条形的长度(或高度)代表该类别数据的数值大小。
  • 特点:
    直观易懂:柱状图通过条形的高度或长度直接反映数据的数值大小,使得数据之间的对比一目了然。
    易于比较:当需要比较不同类别之间的数据时,柱状图可以清晰地展示它们之间的数量关系,帮助用户快速识别出数据的差异和趋势。
    支持多组数据:柱状图可以同时展示多组数据,每组数据使用不同的颜色或标记进行区分,便于用户进行多组数据的比较和分析。
    易于扩展:柱状图可以与其他数据可视化元素结合使用,如添加数据标签、图例、坐标轴等,以提供更丰富的信息。
  • 用途:
    数据分析:柱状图常用于数据分析中,帮助用户快速了解数据的分布情况和特征,发现数据中的规律和问题。
    业务报告:在业务报告中,柱状图可以用来展示销售数据、市场份额、用户活跃度等指标,帮助决策者了解业务状况并做出决策。
    科学研究:在科学研究领域,柱状图可以用来展示实验数据、调查结果等,帮助研究人员分析数据并得出结论。
# 使用plotly的express模块来绘制一个饼图,展示不同地区的二手车销售数量  
iplot(  
    px.pie(  
        values=df['Region'].value_counts(),  # 从df的'Region'列中获取每个地区的销售数量  
        names=['中部','西部','东部','南部'],  # 这里直接指定了地区的名称,但通常应该从数据中获取  
        title='分地区二手车销量占比图'  # 设置饼图的标题  
    ).update_traces(textinfo='label+percent')  # 更新图表的轨迹设置,添加标签和百分比信息  
)

在这里插入图片描述

# 燃料分析
print(f"Top Fuel Used in Used car '{df['fuel'].value_counts().idxmax()}'")
print(f"Least Fuel Used in Used car '{df['fuel'].value_counts().idxmin()}'")
unique_fuels = df['fuel'].unique().tolist()  # 获取所有唯一的燃料类型  
iplot(  
    px.pie(  
        values=df['fuel'].value_counts(),  # 获取每种燃料类型的频数
        names=unique_fuels,  # 使用实际的燃料类型列表  
        title='使用燃料类型占比图'  
    ).update_traces(textinfo='label+percent')  # 更新饼图的跟踪信息,以显示标签和百分比 
)  

在这里插入图片描述

# 打印最常见的卖家类型  
print(f"Most Type of Seller '{df['seller_type'].value_counts().idxmax()}'")  
# .value_counts() 方法统计'seller_type'列中每种卖家类型的频数  
# .idxmax() 方法返回频数最高的卖家类型的索引,即最常见的卖家类型  
  
# 使用plotly的express模块绘制一个饼图,展示不同卖家类型在二手车销售中的比例  
iplot(  
    px.pie(  
        values=df['seller_type'].value_counts(),  # 获取每种卖家类型的频数  
        names=['Individual','Dealer','Trustmark_Dealer'],  # 这里直接指定了卖家类型的名称,但可能与实际数据不匹配  
        title='二手车卖家类型占比图'  # 设置图表的标题  
    ).update_traces(textinfo='label+percent')  # 更新饼图的跟踪信息,以显示标签和百分比  
)  

在这里插入图片描述
饼图是一种用于表示不同类别的数据在总量中所占比例的图形。以下是关于饼图的详细解释:

  • 定义: 饼图(Pie
    Chart),也称为扇形图或圆饼图,是一个圆形图表,用于展示不同部分与整体之间的关系。它通过将圆形划分为若干个扇区(或称为“切片”),每个扇区代表一个数据类别,扇区的大小(即角度或面积)表示该类别在总体中所占的比例。
  • 特点: 直观性:饼图通过扇区的大小直观地展示不同类别在总体中的占比情况,易于理解和分析。
    完整性:所有扇区的面积之和等于整个圆的面积,即100%,这表示数据的完整性。
    对比性:通过对比不同扇区的大小,可以清晰地看出不同类别之间的比例关系。
  • 制作要点: 数据准备:首先,需要准备好需要展示的数据,并确保所有数据的总和为100%。
    扇区划分:根据数据的比例关系,将圆形划分为若干个扇区。每个扇区的角度或面积应与其在总体中所占的比例相对应。
    颜色选择:为了增强图表的可读性和美观性,可以为不同的扇区选择不同的颜色或图案。
    标注:在每个扇区中,可以添加相应的标签或百分比标注,以便更清晰地展示每个类别的具体占比情况。
  • 应用场景: 群体构成分析:如市场调研中,可以使用饼图展示不同年龄段、性别或教育程度的调查对象在总人口中的比例。
    投资组合分析:投资者可以使用饼图展示不同资产在投资组合中的比例,以便管理风险和优化投资组合。
    销售数据分析:通过饼图展示不同产品或服务在整体销售额中的占比情况,有助于企业了解各类产品或服务的销售情况,进而调整销售策略和资源分配。
    用户满意度调查:企业可以使用饼图展示用户对产品或服务的满意度分布情况,以便改进产品或服务,提升用户满意度和忠诚度。
# 打印销售二手车最多的省或州  
print(f"Top State or Province where Sold Used car '{df['State or Province'].value_counts().idxmax()}'")  
# .value_counts() 方法统计'State or Province'列中每个省或州的频数  
# .idxmax() 方法返回频数最高的省或州的索引,即销售二手车最多的省或州  
  
# 打印销售二手车最少的省或州  
# 注意:如果有多个省或州的计数都是最少的,那么这只会返回其中一个  
print(f"Least State or Province where Sold Used car '{df['State or Province'].value_counts().idxmin()}'")  
# .idxmin() 方法返回频数最低的省或州的索引,即销售二手车最少的省或州  
  
# 使用plotly的express模块绘制一个水平柱状图,展示销售二手车数量排名前30的省或州  
iplot(  
    px.bar(  
        df['State or Province'].value_counts().sort_values(ascending=True)[:30],  # 获取销售数量排名前30的省或州及其频数  
        orientation='h',  # 设置柱状图为水平方向  
        color=df['State or Province'][:30].index,  # 这里设置颜色通常不会按预期工作,因为这里索引可能与排序后的数据不匹配  
        title='二手车销售地区Top榜',  # 设置图表的标题  
        labels={'value':'销售数量'}  # 设置图表的标签,这里只设置了y轴(即省或州)的计数标签  
    )  
)  

在这里插入图片描述

# 打印销售二手车最多的城市  
print(f"Top City where Sold Used car '{df['City'].value_counts().idxmax()}'")  
# .value_counts() 方法统计'City'列中每个城市的频数  
# .idxmax() 方法返回频数最高的城市的索引,即销售二手车最多的城市  
  
# 打印销售二手车最少的城市  
# 注意:如果有多个城市的计数都是最少的,那么这只会返回其中一个  
print(f"Least City where Sold Used car '{df['City'].value_counts().idxmin()}'")  
# .idxmin() 方法返回频数最低的城市的索引,即销售二手车最少的城市  
  
# 使用plotly的express模块绘制一个柱状图,展示销售二手车数量排名前20的城市  
iplot(  
    px.bar(  
        df['City'].value_counts().sort_values(ascending=False)[:20],  # 获取销售数量排名前20的城市及其频数  
        color=df['City'][:20].index,  # 这里设置颜色通常不会按预期工作,因为这里的索引可能与排序后的数据不匹配  
        title='二手车销售城市Top榜',  # 设置图表的标题  
        labels={'value':'数量', 'City':'城市'},  # 设置图表的标签,这里设置了y轴的计数标签  
        text_auto=True  # 自动在柱状图上显示频数值  
    )  
)  

在这里插入图片描述

# 使用plotly的express模块绘制一个水平柱状图,展示二手售出车中最常见的20个转矩值  
  
# iplot 函数用于在Jupyter Notebook等环境中交互式地显示plotly图表  
iplot(  
    # 使用px.bar绘制水平柱状图  
    px.bar(  
        # 对'torque'列中的转矩值进行计数,并按计数降序排列,取前20个  
        df['torque'].value_counts().sort_values(ascending=False)[:20],    
        # 设置柱状图为水平方向  
        orientation='h',            
        # 尝试设置颜色,但这里使用df['torque'][:20].index是不正确的,因为它会取前20个转矩值的索引,而不是计数  
        # 应该使用一个颜色列表来指定柱状图的颜色  
        color=df['torque'][:20].index,  # 注释:这行代码可能是错误的,因为value_counts()的结果与原始数据的索引不匹配            
        # 设置图表的标题  
        title='二手车常见转矩TOP20',            
        # 设置图表的标签,但这里labels的用法可能不准确,plotly通常使用更直接的方式设置轴标签  
        labels={'value':'Count','torque':'Torque'}  # 注释:这行代码可能不会按预期工作,因为plotly使用不同的参数来设置轴标签  
    )  
    .update_traces(textposition='outside')  # (假设代码原本还包括这行)用于在柱状图外部显示数值标签  
    .update_layout(xaxis_title='Torque', yaxis_title='Count')  # 正确的设置轴标签的方式  
)  

在这里插入图片描述
水平柱状图,作为柱状图的一种变体,其特点在于条形是水平放置的,与常见的垂直柱状图形成对比。以下是关于水平柱状图的详细解释:

  • 定义:
    水平柱状图,也称为横向柱状图或条形图,是通过一系列水平放置的条形来展示不同类别的数据,其中条形的长度表示数据的数值大小。与垂直柱状图相比,水平柱状图在数据分类标签较长时更为适用。
  • 特点: 水平展示:与垂直柱状图不同,水平柱状图的条形是水平放置的,这使得在标签较长或需要更多空间展示标签时更为方便。
    易于阅读:水平柱状图同样能够清晰地展示数据的对比关系和分布情况,其直观性使得数据解读更为简单直接。
    适合长标签:当数据的分类标签较长时,水平柱状图可以更好地利用空间,避免标签之间的重叠或截断。
  • 用途: 数据对比:水平柱状图适用于展示不同类别数据之间的对比情况,如销售额、用户活跃度等。
    时间序列数据:尽管垂直柱状图在时间序列数据的展示上更为常见,但水平柱状图在某些情况下也能很好地体现数据随时间的变化情况。
    大屏展示:由于水平柱状图在大屏中占用的空间较大,因此在大屏数据可视化项目中,水平柱状图可以作为一种有效的展示方式。
  • 制作要点: 标签方向:由于条形是水平放置的,因此标签通常位于条形的下方或上方,以便与条形相对应。
    颜色搭配:与垂直柱状图一样,水平柱状图也需要注意颜色搭配的合理性,以确保图表的清晰度和美观度。
    数值标注:在每个条形上方或下方标注具体的数值,有助于更直观地了解数据的具体大小。
# 行驶里程分析
# 创建一个新的图形窗口,并设置其大小为宽度15英寸,高度6英寸  
plt.figure(figsize=(15,6))    
# 使用seaborn库中的kdeplot函数来绘制df['mileage']列(即行驶里程)的核密度估计图  
# fill=True参数表示填充曲线下的区域,使图形更加直观  
sns.kdeplot(df['mileage'], fill=True)    
# 设置x轴的标签为"Mileage",即行驶里程  
plt.xlabel("行驶里程")    
# 显示图形  
plt.show()

在这里插入图片描述在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
本篇废话不多,全是干货。

创作不易,点赞、评论、转发三连走起!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/730756.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

掌握数据魔方:Xinstall引领ASA全链路数据归因新纪元

一、引言 在数字化时代,数据是App推广和运营的核心驱动力。然而,如何准确获取、分析并应用这些数据,却成为了许多开发者和营销人员面临的痛点。Xinstall作为一款专业的App全渠道统计服务商,致力于提供精准、高效的数据解决方案&a…

Linux开发讲课8--- linux的5种IO模型

一、这里IO是什么 操作系统为了保护自己,设计了用户态、内核态两个状态。应用程序一般工作在用户态,当调用一些底层操作的时候(比如 IO 操作),就需要切换到内核态才可以进行 服务器从网络接收的大致流程如下&#xff1…

拍卖商城开发要点源码及功能分析

要创建一个正规的拍卖商城平台,需要遵循一系列步骤,确保平台的合法性、专业性和用户体验。以下是一个详细的步骤指南: 一、明确平台定位与规划 确定拍卖商城平台的目标市场、用户群体和主要拍卖品类。 制定平台的发展规划和战略目标&#…

gorm 学习笔记 五:自定义数据类型和枚举

一:Json类型 Info保存到数据库时,通过Value()转化为json,读取出来的时候 json字符串自动转成结构体Info type Info struct {Status string json:"status"Addr string json:"addr"Age int json:"age"…

无人机比赛有哪些?

无人机比赛项目可是多种多样,精彩纷呈呢! 常见的比赛项目包括S形绕桩赛、平台起降赛、应用航拍、投掷物品和定点飞行等。这些项目不仅考验无人机的性能,更考验飞行员的操控技巧。 在S形绕桩赛中,飞行员需要操控无人机快速而准确…

云计算技术高速发展,优势凸显

云计算是一种分布式计算技术,其特点是通过网络“云”将巨大的数据计算处理程序分解成无数个小程序,并通过多部服务器组成的系统进行处理和分析这些小程序,最后将结果返回给用户。它融合了分布式计算、效用计算、负载均衡、并行计算、网络存储…

初识 GPT-4 和 ChatGPT

文章目录 LLM 概述理解 Transformer 架构及其在 LLM 中的作用解密 GPT 模型的标记化和预测步骤 想象这样⼀个世界:在这个世界里,你可以像和朋友聊天⼀样快速地与计算机交互。那会是怎样的体验?你可以创造出什么样的应用程序?这正是…

市场价格到底是因为什么而变动?

在外汇及广泛的金融市场中,影响金融工具价格起伏的因素纷繁复杂。然而,万变不离其宗,无论是哪个市场,价格的最终决定力量始终是供需之间的平衡法则。 对于外汇、大宗商品等金融市场而言,表面上似乎受宏观经济数据、央…

分享HTML显示2D/3D时间

效果截图 实现代码 <!DOCTYPE html> <head> <title>three.jscannon.js Web 3D</title><meta charset"utf-8"><meta name"viewport" content"widthdevice-width,initial-scale1,maximum-scale1"><meta n…

基于组件的架构:现代软件开发的基石

目录 前言1. 基于组件的架构概述1.1 什么是组件&#xff1f;1.2 组件的分类 2. 基于组件的架构的优势2.1 提高代码的可重用性2.2 增强系统的灵活性2.3 简化维护和升级2.4 促进团队协作 3. 实现基于组件的架构3.1 识别和定义组件3.2 设计组件接口3.3 组件的开发和测试3.4 组件的…

Python 爬取淘宝指定搜索商品评论 标题 销量 计算sign

只需要替换原来的Cookie和token即可使用&#xff0c;自动计算对应链接地址的sign直接使用即可。需要注意是一个账号爬取过多会有验证码 import json import hashlib import random import timeimport pandas as pd import requestsresults []def fetch_review_list(datas, md…

张大哥笔记:5种信息差赚钱模式

从古至今&#xff0c;赚钱最快的路子就一个&#xff0c;而且从未改变&#xff0c;那就是信息差&#xff01;在商业活动中&#xff0c;信息不对称现象普遍存在&#xff0c;如果你善于利用这些信息差的话&#xff0c;就可以赚到钱&#xff01; 1、价格的信息差 商品价格在不同地…

【LLM-多模态】高效多模态大型语言模型综述

一、结论写在前面 模型规模的庞大及训练和推理成本的高昂&#xff0c;限制了MLLMs在学术界和工业界的广泛应用。因此&#xff0c;研究高效轻量级的MLLMs具有巨大潜力&#xff0c;特别是在边缘计算场景中。 论文深入探讨了高效MLLM文献的领域&#xff0c;提供了一个全面的视角…

FLASH闪存

一、FLASH简介 1、FLASH简介 &#xff08;1&#xff09;STM32F1系列的FLASH包含程序存储器、系统存储器和选项字节三个部分&#xff0c;通过闪存存储器接口&#xff08;外设&#xff09;可以对程序存储器和选项字节进行擦除和编程 &#xff08;2&#xff09;读写FLASH的用途…

Setapp AI 怎么样,值得订阅吗?

Setapp 是一款提供 240 多款 Mac 软件库&#xff0c;可以满足 Mac 和 iOS 用户的各种需求。只需支付一笔订阅费&#xff0c;就可以使用一系列应用程序&#xff0c;这些应用程序可以简化任务、提高创造力和组织工作流程。不过&#xff0c;Setapp 并不只注重应用程序的数量&#…

Transformer预测 | 基于Transformer的风电功率多变量时间序列预测(Matlab)

文章目录 预测效果文章概述模型描述程序设计参考资料预测效果 文章概述 Transformer预测 | 基于Transformer的风电功率多变量时间序列预测(Matlab) Transformer 模型本质上都是预训练语言模型,大都采用自监督学习 (Self-supervised learning) 的方式在大量生语料上进行训练,…

【机器学习300问】127、怎么使用词嵌入?

在探讨如何使用词嵌入之前&#xff0c;我们首先需要理解词嵌入模型的基础。之前的文章已提及&#xff0c;词嵌入技术旨在将文本转换为固定长度的向量&#xff0c;从而使计算机能够解析和理解文本内容。可以跳转下面链接去补充阅读哦&#xff01; 【机器学习300问】126、词嵌入…

【链表经典面试题】LeetCode138.复制带随机指针的链表(链表深拷贝)

&#x1f4c7;文章目录 &#x1f680;题目描述&#x1f680;思路1&#xff1a;&#x1f680;思路2&#xff1a;&#x1f680;完整代码 &#x1f680;题目描述 解读&#xff1a; 题目意思就是 给你一个链表 这个链表中除了有next指针之外 还有一个指向这个链表的随机位置的一个指…

简易人工智能入门

一、监督or非监督 监督学习&#xff08;Supervised Learning&#xff09;&#xff1a;训练集有标记信息&#xff08;Y&#xff09;&#xff0c;学习方式有分类和回归 无监督学习&#xff08;Unsupervised Learning&#xff09;&#xff1a;训练集没有标记信息&#xff0c;学习…

事件驱动架构详解:触发与响应构建高效系统

目录 前言1. 事件驱动架构概述1.1 什么是事件1.2 事件驱动架构的核心概念 2. 事件驱动架构的实现2.1 基于消息队列的实现2.2 基于发布-订阅模式的实现2.3 基于流处理的实现 3. 事件驱动架构的优势3.1 松耦合性3.2 可扩展性3.3 异步处理3.4 灵活性 4. 事件驱动架构的应用场景4.1…