python使用cartopy庫繪制臺(tái)風(fēng)路徑代碼
使用python基于cartopy庫繪制臺(tái)風(fēng)路徑

使用python 繪制西太平洋進(jìn)入我國(guó)的臺(tái)風(fēng)路徑,文件為.dat格式,內(nèi)容如下所示:

代碼如下:
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)) #設(shè)置畫布大小
parallels = np.arange(0.,90.,3.)
meridians = np.arange(0.0,360.,3.)
ax = plt.axes(projection=ccrs.Robinson()) #設(shè)置投影方式
# Set figure extent & ticks
ax.set_extent([100, 150, 5, 50]) #設(shè)置緯度范圍
# plt.grid(linestyle=':',color='y')#
for file in files: #按照順序在 files 里面進(jìn)行每一個(gè)文件的 數(shù)據(jù)名稱 循環(huán)讀取
f = open(path+file,'r') # 打開第一個(gè) dat 文件
records = f.readlines() # 讀取這個(gè)文件里面的所有數(shù)據(jù)
f.close() # 關(guān)閉這個(gè)dat文件
date_t = '' # 設(shè)置一個(gè)用來表示空格
btk_lat = [] # 設(shè)置一個(gè)空的 待傳入數(shù)據(jù)的緯度
btk_lon = [] # 設(shè)置一個(gè)空的 待傳入數(shù)據(jù)的經(jīng)度
btk_vmax = [] # 風(fēng)速最大值 Maximum sustained wind speed in knots: 0 - 300 kts.
btk_time = [] # 時(shí)間
btk_rmw = [] # 最大風(fēng)速半徑 radius of max winds, 0 - 999 n mi.
btk_name = [] # 臺(tái)風(fēng)名稱
for rcd in records: # 對(duì)這個(gè)dat文件里面,已經(jīng)讀取的每一行數(shù)據(jù)進(jìn)行循環(huán)處理
strs = rcd.split(',') #將每一個(gè)','分隔開
if(len(strs)<21): #判斷語句,如果這個(gè)被分割開的字符 長(zhǎng)度<21 ,繼續(xù)進(jìn)行處理
continue
date_str = strs[2].strip(' ') #將strs這個(gè)list的索引為2的值賦給data_str,既年月日時(shí)
if date_str == date_t:#判讀如果是一個(gè)空格值,賦給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'))#計(jì)算距離給的時(shí)間有多少秒,并從后往前排列
#處理緯度
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)
#處理經(jīng)度
lon_str = strs[7].strip()
#判斷 東西經(jīng)
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)
#處理最大風(fēng)速
vmax = strs[8].strip()
btk_vmax.append(float(vmax))#轉(zhuǎn)換為單浮點(diǎn)型,(帶小數(shù)點(diǎn))
#時(shí)間
date_t = date_str
#最大風(fēng)速半徑
rmw = strs[19].strip()
btk_rmw.append(float(rmw))
#處理臺(tái)風(fēng)名稱
if(len(strs) < 27):
btk_name.append('noname')
else:
name = strs[27].strip()
btk_name.append(name)
#==============================================================================
btk_lat = np.array(btk_lat) #將得到的list 值轉(zhuǎn)換為數(shù)組型的值,為了便于繪圖。因?yàn)槔L圖的橫縱坐標(biāo)都是數(shù)組排列
btk_lon = np.array(btk_lon)%360 #因?yàn)樵冀?jīng)度為-180 - 0 -180 ,出現(xiàn)斷隔,為解決問題,化為 0-360
btk_time = np.array(btk_time) #時(shí)間轉(zhuǎn)換
btk_vmax = np.array(btk_vmax)*0.5144 #風(fēng)速換算公式
btk_rmw = np.array(btk_rmw)*1.852 #
#判斷,如果數(shù)組緯度的值是0,則為nan值,既無法計(jì)算的值(無窮大,,),否則即為臺(tái)風(fēng)的名稱
if(len(btk_lat) == 0):
tc_name = 'noname'
else:
index = btk_vmax.argmax()
tc_name = btk_name[index]
#進(jìn)行繪圖,經(jīng)度、緯度曲線
ax.plot(btk_lon,btk_lat,color='k',linewidth=0.5,transform=ccrs.PlateCarree())
#散點(diǎn)圖繪制,經(jīng)度、緯度、最大風(fēng)速,
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)
到此這篇關(guān)于python使用cartopy庫繪制臺(tái)風(fēng)路徑代碼的文章就介紹到這了,更多相關(guān)python cartopy繪制臺(tái)風(fēng)路徑內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
基于python內(nèi)置函數(shù)與匿名函數(shù)詳解
下面小編就為大家分享一篇基于python內(nèi)置函數(shù)與匿名函數(shù)詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-01-01
Python結(jié)合Flask框架構(gòu)建一個(gè)簡(jiǎn)易的遠(yuǎn)程控制系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了如何使用Python與Flask框架構(gòu)建一個(gè)簡(jiǎn)易的遠(yuǎn)程控制系統(tǒng),能夠遠(yuǎn)程執(zhí)行操作命令(如關(guān)機(jī)、重啟、鎖屏等),還具備實(shí)時(shí)屏幕截圖功能,需要的可以參考下2025-03-03
使用python如何提取JSON數(shù)據(jù)指定內(nèi)容
這篇文章主要介紹了使用python如何提取JSON數(shù)據(jù)指定內(nèi)容,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-07-07
python游戲開發(fā)之視頻轉(zhuǎn)彩色字符動(dòng)畫
這篇文章主要為大家詳細(xì)介紹了python游戲開發(fā)之視頻轉(zhuǎn)彩色字符動(dòng)畫,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-04-04
利用Python實(shí)現(xiàn)一個(gè)下班倒計(jì)時(shí)程序
身為打工人,一定是想著下班的那一刻吧,這篇文章主要來和大家介紹一下如何利用Python實(shí)現(xiàn)一個(gè)下班倒計(jì)時(shí)程序,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2023-12-12
Python中return函數(shù)返回值實(shí)例用法
在本篇文章里小編給大家整理的是一篇關(guān)于Python中return函數(shù)返回值實(shí)例用法,有興趣的朋友們可以學(xué)習(xí)下。2020-11-11
Python實(shí)現(xiàn)解析命令行參數(shù)的常見方法總結(jié)
除ide的執(zhí)行方式外,命令行的方式執(zhí)行Python腳本是參數(shù)化程序執(zhí)行的一種常見且簡(jiǎn)單的方法。本文總結(jié)了三個(gè)常見的獲取和解析命令行參數(shù)的方法,需要的可以參考一下2022-10-10

