[Python数据可视化]探讨数据可视化的实际应用:三个案例分析

news/2024/9/21 18:43:59 标签: python, 数据分析, 数据可视化, 信息可视化

        数据可视化是理解复杂数据集的重要工具,通过图形化的方法,可以直观地展示信息、趋势和模式。本文将深入探讨三个实际案例,包括健康数据分析、销售趋势分析、城市交通流量分析。每个案例将提供假设数据、详细注释的代码及分析结果。

案例 1: 健康数据分析

背景

分析城市居民的体重指数(BMI)分布,帮助公共健康部门识别潜在的健康问题。

假设数据

  • age_group: 年龄组(如 "18-25", "26-35", 等)
  • bmi: 体重指数
  • count: 每个年龄组的居民人数

代码

python">import pandas as pd
import matplotlib.pyplot as plt
import seaborn as sns

# 假设数据
data = {
    'age_group': ['18-25', '26-35', '36-45', '46-55', '56-65', '66+'],
    'bmi': [22.0, 24.5, 27.0, 28.5, 29.0, 26.5],
    'count': [200, 300, 250, 150, 100, 50]
}

health_data = pd.DataFrame(data)

# 绘制条形图
plt.figure(figsize=(10, 6))
sns.barplot(x='age_group', y='count', data=health_data, palette='Blues')
plt.title('Distribution of Residents by Age Group', fontsize=16)
plt.xlabel('Age Group', fontsize=14)
plt.ylabel('Number of Residents', fontsize=14)
plt.grid(axis='y')

# 增加BMI指标
for index, row in health_data.iterrows():
    plt.text(index, row['count'] + 5, f"BMI: {row['bmi']}", color='black', ha='center')

plt.show()

分析结果

通过条形图和BMI信息,我们可以看出,年龄较大的群体BMI普遍较高,这可能暗示他们面临更高的健康风险。公共健康部门可以针对高BMI的年龄组开展健康教育和体检活动。


案例 2: 销售数据分析

背景

分析电商平台的销售数据,以识别最佳销售季节,指导营销策略。

假设数据

  • month: 销售月份
  • sales: 销售额(单位:万元)

代码

python"># 假设数据
months = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec']
sales = [20, 35, 30, 40, 50, 70, 90, 100, 80, 60, 50, 30]
promotions = [1, 2, 1, 2, 3, 5, 6, 7, 4, 2, 1, 1]

sales_data = pd.DataFrame({'month': months, 'sales': sales, 'promotions': promotions})

# 绘制双Y轴折线图
fig, ax1 = plt.subplots(figsize=(12, 6))

ax2 = ax1.twinx()
ax1.plot(sales_data['month'], sales_data['sales'], marker='o', color='orange', label='Sales')
ax2.plot(sales_data['month'], sales_data['promotions'], marker='s', color='blue', label='Promotions', linestyle='--')

ax1.set_title('Monthly Sales Trends and Promotions', fontsize=16)
ax1.set_xlabel('Month', fontsize=14)
ax1.set_ylabel('Sales (in ten thousand)', fontsize=14, color='orange')
ax2.set_ylabel('Number of Promotions', fontsize=14, color='blue')

ax1.tick_params(axis='y', labelcolor='orange')
ax2.tick_params(axis='y', labelcolor='blue')
ax1.grid()

fig.legend(loc="upper left", bbox_to_anchor=(0.15, 0.85), bbox_transform=ax1.transAxes)
plt.xticks(rotation=45)
plt.savefig('sales.jpg')
plt.show()

分析结果

折线图展示了销售的季节性趋势。7-8月的销售额达到最高,电商可以在此时增加营销预算以提升销售。


案例 3: 城市交通流量分析

背景

分析城市主要路段的交通流量,识别高峰时段以优化交通管理。

假设数据

  • datetime: 时间(每小时记录一次)
  • road_id: 路段编号
  • vehicle_count: 车辆数量

代码

python"># 假设数据
date_range = pd.date_range(start='2023-01-01', periods=24, freq='h')
road_ids = [1, 2, 3]
vehicle_counts = [np.random.poisson(lam=50 + i*10, size=24) for i in road_ids]

traffic_data = pd.DataFrame({
    'datetime': np.tile(date_range, len(road_ids)),
    'road_id': np.repeat(road_ids, len(date_range)),
    'vehicle_count': np.concatenate(vehicle_counts)
})

# 绘制热力图
plt.figure(figsize=(10, 6))
# 使用 pivot 方法创建数据透视表
heatmap_data = traffic_data.pivot(index='road_id', columns='datetime', values='vehicle_count')
sns.heatmap(heatmap_data, cmap="YlGnBu", cbar_kws={'label': 'Vehicle Count'})
plt.title('Traffic Volume Heatmap', fontsize=16)
plt.xlabel('Hour of the Day', fontsize=14)  # 更新 x 轴标签
plt.ylabel('Road ID', fontsize=14)

# 设置 x 轴刻度标签
plt.xticks(np.arange(0.5, heatmap_data.shape[1] + 0.5, 1), np.arange(1, heatmap_data.shape[1] + 1))

plt.tight_layout()
plt.savefig('Traffic.jpg')
plt.show()

分析结果

热力图显示了不同路段在一天内的交通流量变化,高峰时段明显,交通管理部门可以根据这些数据优化信号灯时长和交通流向。


总结

以上三个案例展示了数据可视化在健康、销售、交通中的实际应用。通过直观的图形化展示,决策者能够快速理解数据背后的趋势与模式,为优化策略提供数据支持。这些示例强调了数据可视化的重要性,能够帮助各行各业做出更为明智的决策。


http://www.niftyadmin.cn/n/5669274.html

相关文章

mdadm 命令:软RAID管理

一、命令简介 ​mdadm​ 是 Linux 下用于管理软件 RAID 设备的工具,可以创建、管理和监控软件 RAID 阵列。 ‍ 创建 RAID 需要多个环节,多个命令搭配使用: ​gdisk​ ​命令创建格式为 Linux RAID​ ​的磁盘分区​mdadm​ ​命令将多个 …

web 动画库

web动画库 动画领域有一个比较知名的CSS库:Animate.css,它提供了60多种动画,满足一般网页的需求,比如淡入淡出、闪现等等一系列日常动画,不过虽然它能满足日常需求,但是一些复杂的场景就需要靠JS手动去操作…

oracle 11g写一个判断是否是身份证的函数,函数名称为:FUN_IS_IDENNO

下面是一个用于判断是否是身份证号码的Oracle 11g函数(FUN_IS_IDENNO)。身份证号码通常为18位(或者旧的15位),前17位为数字,第18位为数字或字母X,并且需要符合一定的规则,例如出生日…

开源网安多城联动、多形式开展网安周公益活动,传播网络安全知识

9月9日至15日,以“网络安全为人民,网络安全靠人民”为主题的2024年国家网络安全宣传周将在全国范围内统一开展,通过多样的形式、丰富的内容,助力全社会网络安全意识和防护技能提升。开源网安今年继续为各地企业、群众带来了丰富的…

在HTML中添加视频

在HTML中添加视频&#xff0c;你可以使用<video>标签。这个标签允许你在网页上嵌入视频内容&#xff0c;并支持多种视频格式&#xff0c;如MP4、WebM和Ogg等。不过&#xff0c;由于浏览器对视频格式的支持程度不同&#xff0c;因此通常建议提供多种格式的视频文件&#x…

传知代码-多示例AI模型实现病理图像分类

代码以及视频讲解 本文所涉及所有资源均在传知代码平台可获取 概述 本文将基于多示例深度学习EPLA模型实现对乳腺癌数据集BreaKHis_v1的分类。EPLA模型是处理组织病理学图像的经典之作。EPLA模型是基于多示例学习来进行了&#xff0c;那么多示例学习模型对处理病理学图像具有…

github上传文件【傻瓜式方法,无需敲一行代码】

github上传文件 1.新建仓库 2.填仓库名称&#xff0c;记得勾选添加readme&#xff0c;方便后续传文件 3.上传代码 4.readme里面图片的地址记得改成你文件夹里的图片上传到git的地址

周末愉快!——周复盘

加班的晚上有一个美梦&#xff01; 周末愉快简单复盘结尾 精华&#xff1a; 在这个信息爆炸的时代&#xff0c;我们的大脑每天都被无数的数据和刺激充斥&#xff0c;以至于我们常常感到应接不暇。然而&#xff0c;正如古人所言&#xff1a;“不飞则已&#xff0c;一飞冲天”&am…