和鲸社区数据分析每周挑战【第九十三期:特斯拉充电桩分布分析】

和鲸社区数据分析每周挑战【第九十三期:特斯拉充电桩分布分析】

文章目录

  • 和鲸社区数据分析每周挑战【第九十三期:特斯拉充电桩分布分析】
    • 一、前言
    • 二、数据读取和初步探索
    • 三、数据探索及可视化
      • 1、获取拥有最多充电站的 10 个国家
      • 2、一年中各月新开业数量的变化
      • 3、中国各省的充电桩数量分布
      • 4、全球特斯拉超级充电站分布图

一、前言

本周的挑战内容为:特斯拉充电桩分布分析

大家可以去关于特斯拉超级充电站数据集(全球)的探索在线或者下载到本地进行运行这个项目。

在这里插入图片描述

数据集来源本次活动提供:

在这里插入图片描述

在这里插入图片描述

二、数据读取和初步探索

import pandas as pd
import matplotlib.pyplot as plt
import seaborn as sns
import plotly.express as px # 交互式可视化
import folium   # 地图可视化

data = pd.read_csv("Supercharge Locations.csv")
data.head()

在这里插入图片描述

data.describe() # 查看数据的基本统计信息

在这里插入图片描述

data.isnull().sum() # 查看数据是否有缺失值
Supercharger         0
Street Address       0
City                 0
State              123
Zip               1928
Country              0
Stalls               0
kW                   6
GPS                  0
Elev(m)              2
Open Date          781
dtype: int64

三、数据探索及可视化

1、获取拥有最多充电站的 10 个国家

#隐藏警告
import warnings
warnings.filterwarnings("ignore")               #忽略警告信息
plt.rcParams['font.sans-serif']  = ['SimHei'] # 用来正常显示中文标签
plt.rcParams['axes.unicode_minus'] = False      # 用来正常显示负号
plt.rcParams['figure.dpi']  = 100        #分辨率

top_10_countries = data['Country'].value_counts().head(10)

# 创建条形图
plt.figure(figsize=(10, 6))
sns.barplot(x=top_10_countries.index, y=top_10_countries.values)
plt.xlabel('国家')
plt.ylabel('充电站的数量')
plt.title('拥有最多充电站的 10 个国家')
plt.xticks(rotation=45)
plt.show()

在这里插入图片描述

我们不难发现美国共有超过1100座特斯拉充电站,是世界上特斯拉充电站最多的国家。此外,荷兰、德国、中国等国家的充电站数量也比较多。

2、一年中各月新开业数量的变化

# 将开放日期列转换为日期时间格式
data['Open Date'] = pd.to_datetime(data['Open Date'])

# 提取年份和月份作为新的列
data['Year'] = data['Open Date'].dt.year
data['Month'] = data['Open Date'].dt.month

# 计算每个月的新开业数量
monthly_openings = data.groupby(['Year', 'Month']).size().reset_index(name='Count')

# 创建折线图
plt.figure(figsize=(10, 6))
sns.lineplot(data=monthly_openings, x='Month', y='Count', hue='Year', marker='o')
plt.xlabel('月份')
plt.ylabel('新开业数量')
plt.title('一年中各月新开业数量的变化')
plt.legend(title='月份', loc='upper left')
plt.xticks(range(1, 13))
plt.show()

在这里插入图片描述

根据图像我们可以发现新开业数量呈现出了明显的季节性变化,每年四月、六月和十月都有比较多的新开业数量,而一月、七月和十一月则有比较少的新开业数量。

3、中国各省的充电桩数量分布

china_data = data[data['Country'] == 'China']

# 按省份统计充电桩数量
province_counts = china_data['State'].value_counts()

# 创建条形图
plt.figure(figsize=(10, 6))
province_counts.plot(kind='bar')
plt.xlabel('省份')
plt.ylabel('充电桩数量')
plt.title('中国各省的充电桩数量分布')

# 显示图表
plt.show()

在这里插入图片描述

根据图像我们可以发现在中国,广东、上海和北京的充电桩数量排名前三,其它各省的充电桩数量都比较分散。

4、全球特斯拉超级充电站分布图

# 从GPS列中提取经度和纬度
data[['Latitude', 'Longitude']] = data['GPS'].str.extract(r'([-\d\.]+), ([-\d\.]+)').astype(float)

# 创建地理散点图
fig = px.scatter_geo(data,
                     lat="Latitude",
                     lon="Longitude",
                     hover_name="Supercharger",
                     text="Stalls",
                     color="Country",
                     projection="natural earth")

# 更新布局和标题
fig.update_layout(title="全球特斯拉超级充电站分布图")

# 显示图表
fig.show()

在这里插入图片描述

根据图像我们可以发现全球特斯拉充电站分布比较集中,美国、欧洲、中国和澳大利亚都有较为密集的充电站分布,其它地区的充电站数量相对较少。

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

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

相关文章

微软wsl2 + ubantu + docker + 部署本地项目

windows 操作系统版本要达到要求 开启 wsl2 安装实用工具 Windows Terminal 和 Visual Studio Code 安装 Ubuntu 子系统 安装 Docker Desktop 并让 Docker Desktop 基于 wsl2 来运行 基础环境准备可以完全参照《搭建 Laravel Sail 开发环境 - Windows》来进行,我跟教…

微信小程序基础使用-请求数据并渲染

小程序基本使用-请求数据并渲染 小程序模板语法-数据绑定 在js中定义数据 Page({data: {isOpen: true,message: hello world!} })小程序的data是一个对象,不同于vue的data是一个函数 在模块中获取使用数据 小程序中使用 {{}} 实现数据与模板的绑定 内容绑定&a…

Spring Boot整合JPA

文章目录 一、Spring Boot整合JPA(一)创建Spring Boot项目JPADemo(二)创建ORM实体类1、创建评论实体类 - Comment2、创建文章实体类 - Article (三)创建自定义JpaRepository接口 - ArticleRepository&#…

1.数据库的基本操作

SQL句子中语法格式提示: 1.中括号([])中的内容为可选项; 2.[,...]表示,前面的内容可重复; 3.大括号({})和竖线(|)表示选择项,在选择…

【Axure 教程】中继器(基础篇)

一、初识中继器 中继器是 Axure 中一个比较高阶的应用,它可以让我们在纯静态网页中模拟出类似带有后台数据交互的增删改查的效果,虽然它没有真正意义上帮我们存储任何的数据,但是当我们在一次项目体验过程中,它却可以给我们带来更…

如何获取HTTP请求时间与响应时间【附源码】

文章目录 一、问题描述二、抓包观察三、查找文档四、思考尝试五、精益求精六、源码解说 一、问题描述 今日遇到了一个问题,要去获取HTTP报文在请求和响应的时间,因为没有原生的API可以调用,所以需要一定的技巧~ 下面主体的框架和代码&#xf…

Vue中如何进行样式绑定?

Vue中如何进行样式绑定? 在Vue中,我们可以很方便地进行样式绑定。样式绑定是将CSS样式与Vue组件中的数据进行关联的一种技术。通过样式绑定,我们可以根据组件的状态动态地修改其外观。本文将介绍Vue中的样式绑定,包括类绑定、内联…

软件外包开发项目原型图工具

项目原型图工具有非常重要的作用,尤其是在APP项目开发中,对于整体需求的表达是必不可少的工具。相比于传统的文档需求,图形文字的表达可以更清楚的表达需求,让客户清楚的明白软件功能有哪些,最后的界面是怎样的&#x…

Haproxy搭建Web群集

Haproxy搭建Web群集 1.Haproxy相关概念1.1 Haproxy的概述1.2 Haproxy的主要特性1.3 常见的Web集群调度器 2.常见的应用分析2.1 LVS 应用2.2 Haproxy 应用2.3 LVS、Nginx、Haproxy的区别2.4 Haproxy调度算法原理 3. Haproxy命令行详解3.1 HAProxy服务的5个域3.2 Haproxy服务器配…

【无功优化】基于改进教与学算法的配电网无功优化【IEEE33节点】(Matlab代码时候)

💥💥💞💞欢迎来到本博客❤️❤️💥💥 🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。 ⛳️座右铭&a…

苹果新专利曝光:AirTags可以快速找到Apple Pencil

近日,据外媒报道,苹果一项新专利提出,苹果手写笔可以通过“声学谐振器”来帮助用户找出手写笔的位置。根据这项专利,苹果试图在手写笔的笔盖上加入一个被动元件,以响应特定的声波频率。iPhone、iPad或Apple Watch会发出…

插入排序代码

时间复杂度O(n)

Nik Color Efex 滤镜详解(2/5)

交叉冲印 Cross Processing 提供多种选项来处理 C41 - E6(用幻灯片显影液处理彩色底片)和 E6 - C41(用彩色底片显影液处理幻灯片)。 方法 Method 选择预设。 强度 Strength 控制滤镜效果程度。 黑暗对比度 Dark Contrasts 使用新…

六一,用前端做个小游戏回味童年

#【六一】让代码创造童话,共建快乐世界# 文章目录 📋前言🎯简简单单的弹球游戏🎯代码实现📝最后 📋前言 六一儿童节。这是属于孩子们的节日,也是属于我们大人的节日(过期儿童&…

Intellij IDEA设置“选中变量或方法”的背景颜色、字体颜色(Mark Occurrences)

背景 IDEA 中选中一个变量就会将所有的变量相关变量标出来,这样就很方便知道这个变量出现的地方。Eclipse里头把这个功能叫做 Mark Occurrences,IDEA 里不知道怎么称呼。 我们要解决的痛点就是提示不明显,如下图所示,Macbook这么…

LVS负载均衡群集

文章目录 LVS负载均衡群集1 企业群集1.1 群集cluster的定义1.2 解决办法1.3 企业群集分类1.4 概念1.4.1 负载均衡群集1.4.2 高可用群集1.4.3 高性能运算 群集 2 负载均衡2.1 负载均衡结构2.2 负载均衡群集工作模式2.2.1 NAT模式2.2.2 TUN模式2.2.3 DR模式 3 LVS虚拟服务器3.1 负…

LeetCode 892. Surface Area of 3D Shapes【数组,数学】简单

本文属于「征服LeetCode」系列文章之一,这一系列正式开始于2021/08/12。由于LeetCode上部分题目有锁,本系列将至少持续到刷完所有无锁题之日为止;由于LeetCode还在不断地创建新题,本系列的终止日期可能是永远。在这一系列刷题文章…

大数据基础平台实施及运维

一、大数据介绍 1、为什么使用大数据技术 数据量越来越大,数据分析的实时性越来越强,数据结果应用范围越来越广。(从用户的访问量、量、访问时间、访问频率,市场可以得到很多信息) 2、大数据的定义 数据收集、数据…

使用python制作一个批量查询搜索排名的SEO免费工具

💂 个人网站:【海拥】【摸鱼游戏】【神级源码资源网】🤟 前端学习课程:👉【28个案例趣学前端】【400个JS面试题】💅 寻找学习交流、摸鱼划水的小伙伴,请点击【摸鱼学习交流群】 搭建背景 最近工作中需要用…

【详解】篮球记分牌硬件及代码

篮球记分牌设计 1 系统设计1.1 设计任务 1.2 性能指标要求1.2 设计思路及设计框图1.2.1设计思路1.2.2总体设计框图1.2.3电路原理图1.2.3 PCB布线图 2 主要程序模块的设计及原理2.1 外部中断0 2.2 菜单2.3 两队比分及两队犯规次数显示及修改2.3.1选择功能2.3.2修改功能2.3.3显示…