python批量解析气象文件并转成CSV文件

具体细节请参考上篇文章

完整代码

解析一年的数据

from netCDF4 import Dataset
import csv
import string
import netCDF4 as nf
import datetime
import os

path = r"D:\data\2019\\"
files = os.listdir(path)
print(files)

def getDate(time):
    arr = nf.num2date(nc.variables['time'][:], 'days since 1982-01-01 00:00:00').data
    y = arr[0].year
    m = arr[0].month
    return "%(year)d-%(month)02d"%{'year':y,'month':m}

for file in files:
    # f = open(path+file, "r")
    nc = Dataset(path+file)
    time = nc.variables['time'][:]
    # 纬度 latitude
    Y = nc.variables['Y'][:]
    # 经度 longitude
    X = nc.variables['X'][:]
    # 风速
    Wind_f_tavg = nc.variables['Wind_f_tavg'][:]
    # print(nc.variables.keys())
    print(getDate(time))
    now_time1 = datetime.datetime.now()
    print(now_time1)
    with open(fr'{getDate(time)}.csv', 'a', newline='') as fp:
        writer = csv.writer(fp, delimiter=',', quotechar='"', quoting=csv.QUOTE_MINIMAL)
        #字段名,根据需要可不要
        writer.writerow(['time',
                    'Y',
                    'X',
                    'Wind_f_tavg'
                    ])
        # 输入经纬度的维数
        for i in range(len(time)):
            for j in range(len(Y)):
                for k in range(len(X)):
                    if str(Wind_f_tavg[i][j][k]) not in '--':
                        writer.writerow([getDate(time[i]),
                                         Y[j],
                                         X[k],
                                         Wind_f_tavg[i, j, k]
                                        ])
        fp.close()
        now_time2 = datetime.datetime.now()
        print(now_time2)

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值