python 基于cartopy库绘制台风路径(包含代码详细解释)

简介: python 基于cartopy库绘制台风路径(包含代码详细解释)

使用python基于cartopy库绘制台风路径



a4cb2060da2d48eead767537948ba3a9.png

使用python 绘制西太平洋进入我国的台风路径,文件为.dat格式,内容如下所示:


52ceaea568264894a2d2c8aade17dc85.png


import netCDF4 as nc4
import matplotlib.pyplot as plt
import numpy as np
import datetime
import os
import cartopy.crs as ccrs
path='E://' #文件路径
files= os.listdir(path) #得到文件夹下的所有文件名称
fig=plt.figure(figsize=(20,12)) #设置画布大小
parallels = np.arange(0.,90.,3.) 
meridians = np.arange(0.0,360.,3.)   
ax = plt.axes(projection=ccrs.Robinson())   #设置投影方式
# Set figure extent & ticks
ax.set_extent([100, 150, 5, 50])  #设置纬度范围
# plt.grid(linestyle=':',color='y')#
for file in files:  #按照顺序在 files 里面进行每一个文件的 数据名称 循环读取
    f = open(path+file,'r')   # 打开第一个 dat 文件
    records = f.readlines()   # 读取这个文件里面的所有数据
    f.close()                 # 关闭这个dat文件  
    date_t = ''               # 设置一个用来表示空格
    btk_lat = []              # 设置一个空的 待传入数据的纬度
    btk_lon = []              # 设置一个空的 待传入数据的经度
    btk_vmax = []             # 风速最大值 Maximum sustained wind speed in knots: 0 - 300 kts.
    btk_time = []             # 时间
    btk_rmw = []              # 最大风速半径 radius of max winds, 0 - 999 n mi.
    btk_name = []             # 台风名称
    for rcd in records:       # 对这个dat文件里面,已经读取的每一行数据进行循环处理
        strs = rcd.split(',') #将每一个','分隔开
        if(len(strs)<21):     #判断语句,如果这个被分割开的字符 长度<21 ,继续进行处理
            continue
        date_str = strs[2].strip(' ') #将strs这个list的索引为2的值赋给data_str,既年月日时
        if date_str == date_t:#判读如果是一个空格值,赋给data——str
            continue
        dt = datetime.datetime(int(date_str[0:4]),int(date_str[4:6]),int(date_str[6:8]),\
        int(date_str[8:]),0,0,0)
        btk_time.append(nc4.date2num(dt,units='second since 1970-1-1 00:00:00'))#计算距离给的时间有多少秒,并从后往前排列
        #处理纬度
        lat_str = strs[6].strip()
        #判断南北纬
        if lat_str[-1] == 'N':
            lat_t = float(lat_str[0:-1])*0.1
        else:
            lat_t = float(lat_str[0:-1])*-0.1
        btk_lat.append(lat_t)
        #处理经度
        lon_str = strs[7].strip()
        #判断 东西经
        if lon_str[-1] == 'E':
            lon_t = float(lon_str[0:-1])*0.1
        else:
            lon_t = float(lon_str[0:-1])*-0.1
        btk_lon.append(lon_t)        
        #处理最大风速
        vmax = strs[8].strip()
        btk_vmax.append(float(vmax))#转换为单浮点型,(带小数点)
        #时间
        date_t = date_str
        #最大风速半径
        rmw = strs[19].strip()
        btk_rmw.append(float(rmw))
        #处理台风名称
        if(len(strs) < 27):
            btk_name.append('noname')
        else:
            name = strs[27].strip()
            btk_name.append(name)
#==============================================================================
    btk_lat = np.array(btk_lat) #将得到的list 值转换为数组型的值,为了便于绘图。因为绘图的横纵坐标都是数组排列
    btk_lon = np.array(btk_lon)%360 #因为原始经度为-180 - 0 -180 ,出现断隔,为解决问题,化为 0-360
    btk_time = np.array(btk_time)  #时间转换
    btk_vmax = np.array(btk_vmax)*0.5144 #风速换算公式
    btk_rmw = np.array(btk_rmw)*1.852 #
    #判断,如果数组纬度的值是0,则为nan值,既无法计算的值(无穷大,,),否则即为台风的名称
    if(len(btk_lat) == 0): 
        tc_name = 'noname'
    else:
        index = btk_vmax.argmax()
        tc_name = btk_name[index]
    #进行绘图,经度、纬度曲线
    ax.plot(btk_lon,btk_lat,color='k',linewidth=0.5,transform=ccrs.PlateCarree())
    #散点图绘制,经度、纬度、最大风速,
    cb = ax.scatter(btk_lon,btk_lat,c=btk_vmax,s=10.0,transform=ccrs.PlateCarree()
                    ,vmin=10,vmax=60)
ax.coastlines()
ax.gridlines(draw_labels=True, dms=True, x_inline=False, y_inline=False)
plt.colorbar(cb,label='Vmax (m/s)',pad=0.07,orientation='vertical',shrink=1)
plt.title('  path')
# 保存绘制图片 ,注意保存路径不能放在dat文件夹中     
#fig.savefig(path2+'tester.tiff',format='tiff',dpi=100)


相关文章
|
2月前
|
测试技术 Python
Python装饰器:为你的代码施展“魔法”
Python装饰器:为你的代码施展“魔法”
240 100
|
2月前
|
开发者 Python
Python列表推导式:一行代码的艺术与力量
Python列表推导式:一行代码的艺术与力量
395 95
|
3月前
|
开发者 Python
Python神技:用列表推导式让你的代码更优雅
Python神技:用列表推导式让你的代码更优雅
444 99
|
2月前
|
缓存 Python
Python装饰器:为你的代码施展“魔法
Python装饰器:为你的代码施展“魔法
153 88
|
2月前
|
数据可视化 关系型数据库 MySQL
【可视化大屏】全流程讲解用python的pyecharts库实现拖拽可视化大屏的背后原理,简单粗暴!
本文详解基于Python的电影TOP250数据可视化大屏开发全流程,涵盖爬虫、数据存储、分析及可视化。使用requests+BeautifulSoup爬取数据,pandas存入MySQL,pyecharts实现柱状图、饼图、词云图、散点图等多种图表,并通过Page组件拖拽布局组合成大屏,支持多种主题切换,附完整源码与视频讲解。
238 4
【可视化大屏】全流程讲解用python的pyecharts库实现拖拽可视化大屏的背后原理,简单粗暴!
|
2月前
|
传感器 运维 前端开发
Python离群值检测实战:使用distfit库实现基于分布拟合的异常检测
本文解析异常(anomaly)与新颖性(novelty)检测的本质差异,结合distfit库演示基于概率密度拟合的单变量无监督异常检测方法,涵盖全局、上下文与集体离群值识别,助力构建高可解释性模型。
310 10
Python离群值检测实战:使用distfit库实现基于分布拟合的异常检测
|
2月前
|
机器学习/深度学习 大数据 关系型数据库
基于python大数据的台风灾害分析及预测系统
针对台风灾害预警滞后、精度不足等问题,本研究基于Python与大数据技术,构建多源数据融合的台风预测系统。利用机器学习提升路径与强度预测准确率,结合Django框架实现动态可视化与实时预警,为防灾决策提供科学支持,显著提高应急响应效率,具有重要社会经济价值。
|
2月前
|
监控 机器人 编译器
如何将python代码打包成exe文件---PyInstaller打包之神
PyInstaller可将Python程序打包为独立可执行文件,无需用户安装Python环境。它自动分析代码依赖,整合解释器、库及资源,支持一键生成exe,方便分发。使用pip安装后,通过简单命令即可完成打包,适合各类项目部署。
教大家用 Python 绘制几棵圣诞树~
今天分享五种用 Python 绘制圣诞树的方法,从基础到高级,效果也不断攀升分为 1 到 5 五个 Level 水平;
教大家用 Python 绘制几棵圣诞树~
|
Java Python

推荐镜像

更多