python Cartopy 船舶轨迹数据可视化 【GPS AIS VMS】

更新
最近又发现了更好用的工具keplergl,基本不需要写代码,拿着数据拆箱即用。
欢迎访问我的这篇博客:酷炫Keplergl


实现功能:将轨迹数据可视化到地图上
适用范围:车辆、船舶 等含有GPS定位系统的均可
编程语言:python


效果展示:
在这里插入图片描述


数据说明:需要”经度“和”纬度“这两列的信息。【63627.csv】
在这里插入图片描述
:如果是西经、南纬,需要是负值哦~


代码实现

import seaborn as sns
import pandas as pd
import matplotlib.pyplot as plt
import numpy as np
from matplotlib import rcParams

import cartopy.feature as cf
import cartopy.crs as ccrs
from cartopy.mpl.ticker import LongitudeFormatter,LatitudeFormatter

rcParams['font.family']=rcParams['font.sans-serif']='SimHei'  #font.family局部字体,font.sans-serif全局字体

df=pd.read_csv(r'C:\Users\admin\Desktop\63627.csv')

fig1=plt.figure()
lon1,lon2,lat1,lat2=119,128,23,35 #最小经度,最大经度,最小纬度,最大纬度
#绘制底图
ax=plt.axes(projection=ccrs.PlateCarree())
ax.set_extent([lon1,lon2,lat1,lat2],crs=ccrs.PlateCarree()) #设置地图展示的范围
ax.add_feature(cf.COASTLINE,lw=0.3)
ax.add_feature(cf.LAND)
ax.add_feature(cf.OCEAN)
ax.add_feature(cf.RIVERS)
#绘制船舶轨迹
sns.scatterplot(data=df,x='longitude',y='latitude',s=1,color='orangered')
#设置x、y轴的刻度
ax.set_xticks(np.arange(lon1,lon2,2))
ax.set_yticks(np.arange(lat1,lat2,2))
lon_formatter=LongitudeFormatter(zero_direction_label=False)
lat_formatter=LatitudeFormatter()
ax.xaxis.set_major_formatter(lon_formatter)
ax.yaxis.set_major_formatter(lat_formatter)
#设置标题和坐标轴名称
plt.title('轨迹可视化')
plt.xlabel("经度")
plt.ylabel('纬度')

plt.show()

更多的功能可以参考官网:Cartopy

  • 3
    点赞
  • 80
    收藏
    觉得还不错? 一键收藏
  • 11
    评论
### 回答1: AIS(Automatic Identification System)是一种基于无线电技术的自动识别系统,常用于航海领域的船舶定位和通信。使用Python进行AIS数据的可视化是一种常见且有效的方式。 要进行AIS数据的可视化,首先需要获取AIS数据。可以通过相关的API或者数据库来获得实时或历史AIS数据。在Python中,可以使用合适的库(如pandas)来处理和读取数据。 一旦获得AIS数据,接下来可以使用各种Python的可视化库,如matplotlib和seaborn,来创建图表和图形。下面是一些常用的AIS数据可视化方法: 1. 船舶位置可视化:使用地图库如basemap或者folium,可以将AIS数据中的船舶位置点绘制在地图上,以显示船舶在海洋中的实时位置。 2. 航线可视化:通过将船舶的历史位置点用线条连接起来,可以绘制出船舶的航线轨迹。这可以帮助分析船舶的移动模式和航线选择。 3. 船舶状态可视化:AIS数据中通常包含了船舶的速度、航向等信息。可以使用柱形图、折线图等方式将这些数据可视化,以便更好地理解和分析船舶的状态变化。 4. 船舶密度热力图:将AIS数据中的船舶位置点进行聚类,并使用热力图展示各个聚类区域的密度变化,可以帮助我们了解船舶活动的热点区域。 5. 船舶速度分布直方图:根据AIS数据中的船舶速度信息,可以创建直方图,以展示船舶速度的分布情况。这有助于了解船舶的运行状态和速度特征。 使用Python进行AIS数据的可视化可以帮助我们更好地理解和分析船舶的行为模式、流量分布以及异常情况。同时,Python具有丰富的数据处理和可视化库,使得我们可以轻松地实现对AIS数据的可视化分析。 ### 回答2: AIS数据是指船舶自动识别系统(Automatic Identification System)所产生的船舶信息数据。使用Python进行AIS数据的可视化可以帮助我们更好地理解和分析船舶活动、交通流量等情况。 要进行AIS数据可视化,首先需要获取AIS数据。可以通过各种途径获得,例如航运公司的数据提供商、船舶跟踪网站等。获取到AIS数据后,我们可以使用Python的数据处理库(例如Pandas)来读取和处理数据。 在数据处理阶段,我们可以对AIS数据进行筛选、清洗和预处理。例如,可以根据时间、地理位置等条件筛选出特定区域、特定时间段的数据。同时,我们还可以将AIS数据与其他地理信息数据(例如地图数据)进行整合,以便进行更全面的可视化分析。 接下来,我们可以使用Python数据可视化库(例如Matplotlib、Seaborn)来进行AIS数据的可视化。常见的可视化方式包括散点图、折线图、热力图等。例如,我们可以使用散点图来展示船舶在不同时间和地理位置的分布情况,以及船舶的速度和航向等信息。同时,我们也可以使用折线图来展示船舶轨迹和航线等。 此外,我们还可以进行更高级的可视化分析,例如基于AIS数据的航行路径规划、船舶活动热点分析等。这些分析可以帮助航运公司、港口管理机构等从AIS数据中获得更多有价值的信息,并支持相关决策的制定和优化。 总之,利用Python进行AIS数据的可视化可以帮助我们更好地理解和分析船舶活动情况。通过适当选择和应用数据处理和可视化工具,我们可以更直观地展示AIS数据的特征和规律,为相关行业和领域提供更好的决策支持。 ### 回答3: AIS数据(船舶自动识别系统)是一种用于船舶位置和运行状态的全球性信息系统。通过AIS数据,可以获取船舶的位置、航向、航速、船名等信息。将AIS数据进行可视化是一种将数据以图形化形式展示的方法,能够更直观地了解船舶的位置和运行状态。 Python是一种功能强大的编程语言,拥有丰富的数据处理和可视化库。在Python中,可以使用著名的数据处理库pandas来处理AIS数据。首先,我们可以使用pandas读取AIS数据,并对数据进行清洗和整理,剔除无效或重复的数据。 接着,可以使用Python的可视化库matplotlibAIS数据进行可视化。使用matplotlib可以绘制折线图、散点图、热力图等多种图表,以直观地展示船舶的位置和运行状态。例如,可以通过绘制散点图来表示船舶在海上的分布情况,使用不同的颜色或大小来表示船舶的不同属性。 此外,还可以使用Python的地理信息处理库geopandas来将AIS数据与地理信息数据进行融合,实现更丰富的可视化效果。例如,可以将AIS数据与地图数据进行叠加,以在地图上显示船舶的位置和运行路径。 综上所述,通过使用Python进行AIS数据可视化,我们可以更直观地了解船舶的位置和运行状态。这不仅有助于海事监管和船舶管理,还可以提供有关船舶运输和航行安全的重要信息。
评论 11
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值