数据可视化案例-基于NetworkX网络的美国飞机航线可视化

2024-03-22 21:50

本文主要是介绍数据可视化案例-基于NetworkX网络的美国飞机航线可视化,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

NetworkX网络数据可视化

我们选用美国飞机航线的数据集,包括起始机场、终点、飞行时间等
注:此处数据集下载地址为:

数据集下载地址

import pandas as pd
import numpy as np 
flights = pd.read_csv('./input/flights.csv') 
flights.shape
flights.columns
Out:(5819079, 31)Index(['YEAR', 'MONTH', 'DAY', 'DAY_OF_WEEK', 'AIRLINE', 'FLIGHT_NUMBER','TAIL_NUMBER', 'ORIGIN_AIRPORT', 'DESTINATION_AIRPORT', 'SCHEDULED_DEPARTURE', 'DEPARTURE_TIME', 'DEPARTURE_DELAY', 'TAXI_OUT','WHEELS_OFF', 'SCHEDULED_TIME', 'ELAPSED_TIME', 'AIR_TIME', 'DISTANCE','WHEELS_ON', 'TAXI_IN', 'SCHEDULED_ARRIVAL', 'ARRIVAL_TIME','ARRIVAL_DELAY', 'DIVERTED', 'CANCELLED', 'CANCELLATION_REASON','AIR_SYSTEM_DELAY', 'SECURITY_DELAY', 'AIRLINE_DELAY','LATE_AIRCRAFT_DELAY', 'WEATHER_DELAY'],dtype='object')
## 检测缺失值
flights.isnull().any() 
Out:YEAR                   FalseMONTH                  FalseDAY                    FalseDAY_OF_WEEK            FalseAIRLINE                FalseFLIGHT_NUMBER          FalseTAIL_NUMBER             TrueORIGIN_AIRPORT         FalseDESTINATION_AIRPORT    FalseSCHEDULED_DEPARTURE    FalseDEPARTURE_TIME          TrueDEPARTURE_DELAY         TrueTAXI_OUT                TrueWHEELS_OFF              TrueSCHEDULED_TIME          TrueELAPSED_TIME            TrueAIR_TIME                TrueDISTANCE               FalseWHEELS_ON               TrueTAXI_IN                 TrueSCHEDULED_ARRIVAL      FalseARRIVAL_TIME            TrueARRIVAL_DELAY           TrueDIVERTED               FalseCANCELLED              FalseCANCELLATION_REASON     TrueAIR_SYSTEM_DELAY        TrueSECURITY_DELAY          TrueAIRLINE_DELAY           TrueLATE_AIRCRAFT_DELAY     TrueWEATHER_DELAY           Truedtype: bool

比如我们想找出哪个机场是热门中转机场,或是我们想从机场A飞到机场B,如果没有直达航班,如何最优选择路线(因为数据集中没有给出费用,所以我们找到时间最短的路线)

那么我们只需要提取三列:起始机场(ORIGIN_AIRPORT),终点机场(DESTINATION_AIRPORT),飞行时间(AIR_TIME),数据集中还包括了字段"CANCELLED",反映了是否取消了航班,所以我们先删除已取消的航班。

flights1 = flights[flights['CANCELLED'] == 0]
flights2 = flights1[['ORIGIN_AIRPORT','DESTINATION_AIRPORT','AIR_TIME']].reset_index(drop=True) ## 提取三列且重新建立索引
## 删除缺失值
flight2 = flights2[flights2['AIR_TIME'].notnull()]

我们先来看看总共有多少个机场

list(set(flights2['ORIGIN_AIRPORT']))[:5]
Out:['14685', '13360', 'ECP', '12892', '12177']

我们发现起始航班中有数字(不是机场名称的缩写),我们认为其是无效的,那么先删除起始机场和到达机场中包含数字的所有行

## 先将这一列转为字符串类型,因为其中的数字有可能是int类型有可能是字符串类型
flights2['ORIGIN_AIRPORT'] = flights2['ORIGIN_AIRPORT'].astype(str)
flights3 = flights2[flights2['ORIGIN_AIRPORT'].str.contains('1|2|3|4|5|6|7|8|9|0')==False]
list(set(flights3['ORIGIN_AIRPORT']))[:5]
Out:['ECP', 'STC', 'ADQ', 'HIB', 'BTV']

现在只留下了机场名的缩写,我们再检查到达机场,看看有没有包含数字。

list(set(flights3['DESTINATION_AIRPORT']))[:5]
len(set(flights3['DESTINATION_AIRPORT']))
## 很不错,也没有,那么我们开始进行下一步处理
Out:['ECP', 'STC', 'ADQ', 'BTV', 'HIB']322

现在将起始机场和到达机场作为节点,若要选择最短时间,其实跟选择最短路径一样,我们将边的属性weight设置为每个航线之间的飞行时间。

## 给图添加边和边的属性 
G = nx.Graph()
for i in range(len(flights3)):G.add_edge(flights3.iloc[i,0],flights3.iloc[i,1],weight = flights3.iloc[i,2])
## 比如我们现在想知道从'ANC'机场取'LAR'机场,如何转机所需时间最短
print(nx.dijkstra_path(G,'ANC','LAR'))
Out:['ANC', 'DEN', 'LAR']
## 画出航线的网络图
nx.draw(G, with_labels=True)

在这里插入图片描述
这样随机分布的机场不直观,也没办法获取机场的地理位置,所以我们把他们画到美国的地图上。

from mpl_toolkits.basemap import Basemap
## 读取机场的数据,包括机场的经纬度和所属的洲
airports = pd.read_csv('./input/airports.csv').drop(['AIRPORT','CITY','COUNTRY'],axis = 1) ## 直接将一些不需要的列删除
## m为生成的美国地图,其中的参数llrnrlon到urcrnrlon是设置美国的经度和维度范围
m = Basemap(projection='merc',llcrnrlon=-150,llcrnrlat=20,urcrnrlon=-50,urcrnrlat=60,lat_0 = 40,lon_0=-100, resolution='l',suppress_ticks=True)
mx,my = m(list(airports['LONGITUDE']),list(airports['LATITUDE']))
pos = {}
for i in range(len(airports)):pos[airports.iloc[i,0]] = (mx[i],my[i])   
## 根据航线来表现节点的大小
deg = nx.degree(G)
sizes = [ 10* deg[i] for i in G.nodes]
## 如果节点过小的话,则不加标签
labels = {i: i if deg[i] >= 20 else '' for i in G.nodes}
## 根据机场所在的洲决定机场节点的颜色,故先给节点添加state属性
for i in range(len(airports)):G.nodes[airports['IATA_CODE'][i]]['state'] = airports['STATE'][i]
## 按照G.nodes中航班的顺序,将其对应的洲排列在一个列表中
state = [ G.nodes[i]['state']   for i in G.nodes]## 将字符串转为数值,因为要按照洲添加颜色
a,indices = np.unique(state,return_inverse=True)
figure = plt.figure(figsize=(30,30))
nx.draw_networkx(G, pos,font_size=16,alpha=.8,width=.075, node_size=sizes,labels=labels,node_color=indices,edge_color='#9400D3')## 绘制地图
m.drawcountries()
m.drawstates()
# m.bluemarble()
m.drawcoastlines()plt.show()

在这里插入图片描述
从图中,我们可以看到东部主要是中转机场,航线比较多,机场也比较密集。

这篇关于数据可视化案例-基于NetworkX网络的美国飞机航线可视化的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/836267

相关文章

MyBatis-Plus通用中等、大量数据分批查询和处理方法

《MyBatis-Plus通用中等、大量数据分批查询和处理方法》文章介绍MyBatis-Plus分页查询处理,通过函数式接口与Lambda表达式实现通用逻辑,方法抽象但功能强大,建议扩展分批处理及流式... 目录函数式接口获取分页数据接口数据处理接口通用逻辑工具类使用方法简单查询自定义查询方法总结函数式接口

MySql基本查询之表的增删查改+聚合函数案例详解

《MySql基本查询之表的增删查改+聚合函数案例详解》本文详解SQL的CURD操作INSERT用于数据插入(单行/多行及冲突处理),SELECT实现数据检索(列选择、条件过滤、排序分页),UPDATE... 目录一、Create1.1 单行数据 + 全列插入1.2 多行数据 + 指定列插入1.3 插入否则更

Python通用唯一标识符模块uuid使用案例详解

《Python通用唯一标识符模块uuid使用案例详解》Pythonuuid模块用于生成128位全局唯一标识符,支持UUID1-5版本,适用于分布式系统、数据库主键等场景,需注意隐私、碰撞概率及存储优... 目录简介核心功能1. UUID版本2. UUID属性3. 命名空间使用场景1. 生成唯一标识符2. 数

SQL中如何添加数据(常见方法及示例)

《SQL中如何添加数据(常见方法及示例)》SQL全称为StructuredQueryLanguage,是一种用于管理关系数据库的标准编程语言,下面给大家介绍SQL中如何添加数据,感兴趣的朋友一起看看吧... 目录在mysql中,有多种方法可以添加数据。以下是一些常见的方法及其示例。1. 使用INSERT I

Python使用vllm处理多模态数据的预处理技巧

《Python使用vllm处理多模态数据的预处理技巧》本文深入探讨了在Python环境下使用vLLM处理多模态数据的预处理技巧,我们将从基础概念出发,详细讲解文本、图像、音频等多模态数据的预处理方法,... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核

PostgreSQL的扩展dict_int应用案例解析

《PostgreSQL的扩展dict_int应用案例解析》dict_int扩展为PostgreSQL提供了专业的整数文本处理能力,特别适合需要精确处理数字内容的搜索场景,本文给大家介绍PostgreS... 目录PostgreSQL的扩展dict_int一、扩展概述二、核心功能三、安装与启用四、字典配置方法

MySQL 删除数据详解(最新整理)

《MySQL删除数据详解(最新整理)》:本文主要介绍MySQL删除数据的相关知识,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、前言二、mysql 中的三种删除方式1.DELETE语句✅ 基本语法: 示例:2.TRUNCATE语句✅ 基本语

Linux中压缩、网络传输与系统监控工具的使用完整指南

《Linux中压缩、网络传输与系统监控工具的使用完整指南》在Linux系统管理中,压缩与传输工具是数据备份和远程协作的桥梁,而系统监控工具则是保障服务器稳定运行的眼睛,下面小编就来和大家详细介绍一下它... 目录引言一、压缩与解压:数据存储与传输的优化核心1. zip/unzip:通用压缩格式的便捷操作2.

Python中re模块结合正则表达式的实际应用案例

《Python中re模块结合正则表达式的实际应用案例》Python中的re模块是用于处理正则表达式的强大工具,正则表达式是一种用来匹配字符串的模式,它可以在文本中搜索和匹配特定的字符串模式,这篇文章主... 目录前言re模块常用函数一、查看文本中是否包含 A 或 B 字符串二、替换多个关键词为统一格式三、提

MyBatisPlus如何优化千万级数据的CRUD

《MyBatisPlus如何优化千万级数据的CRUD》最近负责的一个项目,数据库表量级破千万,每次执行CRUD都像走钢丝,稍有不慎就引起数据库报警,本文就结合这个项目的实战经验,聊聊MyBatisPl... 目录背景一、MyBATis Plus 简介二、千万级数据的挑战三、优化 CRUD 的关键策略1. 查