1. 读取数据并画图

    import os
    import glob
    from datetime import datetime, timedelta
    from satpy.scene import Scene
    from pyresample import get_area_def
    import warnings warnings.filterwarnings('ignore') def fileNameSplit(fileNs):
    fSplit = []
    for fpn in fileNs:
    fp = os.path.dirname(fpn)
    fn = os.path.basename(fpn).split('_P_')[-1]
    nfpn = os.path.join(fp, fn)
    if not os.path.exists(nfpn):
    os.rename(fpn, nfpn)
    fSplit.append(nfpn)
    return fSplit def time_format(info, format="%Y%m%d%H%M%S", format2="%Y%m%d%H%M00"):
    dt = datetime.strptime(info, format)
    strdt = dt + timedelta(hours=8)
    return datetime.strftime(strdt, format2) def get_fy4a(file_paths, channel_list):
    fileTime = time_format(os.path.basename(file_paths[0]).split('_')[-3])
    # 创建scene对象
    scn = Scene(file_paths, reader='agri_l1')
    # 查看可使用的通道
    if 'C03' in channel_list:
    print(scn.available_dataset_names())
    if 'true_color' in channel_list:
    # 查看可用的合成选项
    print(scn.available_composite_names())
    # 读取指定通道数据
    scn.load(channel_list)
    # 打印加载通道后 xarray.Dataset 的数据集
    # print(scn) """
    >python coord2area_def.py china merc 5 54 60 139 3
    ### +proj=merc +lat_0=29.5 +lon_0=99.5 +ellps=WGS84 china:
    description: china
    projection:
    proj: merc
    ellps: WGS84
    lat_0: 29.5
    lon_0: 99.5
    shape:
    height: 2194
    width: 2931
    area_extent:
    lower_left_xy: [-4397119.886334, 553583.846816]
    upper_right_xy: [4397119.886334, 7135562.567523]
    """
    # 画自定义区域图片
    area_id = 'china'
    area_name = "myarea"
    proj_id = 'china_99.5_29.5'
    proj4_args = '+proj=merc +lat_0=29.5 +lon_0=99.5 +ellps=WGS84'
    height = 2194
    width = 2931
    area_extent = [-4397119.886334, 553583.846816, 4397119.886334, 7135562.567523]
    # 定义地图投影和区域,然后将数据投影到该区域上
    areadef = get_area_def(area_id, area_name, proj_id, proj4_args, width, height, area_extent)
    china_scene = scn.resample(areadef) channel_ele = {'C03': 'vis', 'C09': 'vap', 'C12': 'ir', 'true_color': 'thr'}
    for cele in channel_list:
    pic_dir = r'./'
    pic_name = f'fy4a_{channel_ele[cele]}_{fileTime}.png'
    pic_path = os.path.join(pic_dir, pic_name)
    if not os.path.exists(pic_path):
    print(f'生成图片 {pic_name}')
    # 保存图片
    china_scene.save_dataset(cele, filename=pic_path) if __name__ == '__main__':
    t1 = datetime.now() grayFilePathList = ['./FY4A-_AGRI--_N_REGC_1047E_L1-_FDI-_MULT_NOM_20211020022336_20211020022753_4000M_V0001.HDF',
    './FY4A-_AGRI--_N_REGC_1047E_L1-_GEO-_MULT_NOM_20211020022336_20211020022753_4000M_V0001.HDF']
    print(grayFilePathList)
    channelList = ['C03', 'C09', 'C12']
    get_fy4a(grayFilePathList[:1], channelList)
    t2 = datetime.now()
    print(t2 - t1)
    print('------')
    thrFilePathList = ['./FY4A-_AGRI--_N_REGC_1047E_L1-_FDI-_MULT_NOM_20211020022336_20211020022753_4000M_V0001.HDF',
    './FY4A-_AGRI--_N_REGC_1047E_L1-_GEO-_MULT_NOM_20211020022336_20211020022753_4000M_V0001.HDF'] print(thrFilePathList)
    channelList1 = ['true_color']
    get_fy4a(thrFilePathList, channelList1)
    t3 = datetime.now()
    print(t3 - t2)
  2. reader='agri_l1'

    版本<=0.36.0  'agri_l1'     >=0.37.0   'agri_fy4a_l1'   其他请看网址

    https://satpy.readthedocs.io/en/stable/index.html#reader-table

  3. HTTPSConnectionPool(host='zenodo.org', port=443): Max retries exceeded with url: /record/1288441/files/pyspectral_atm_correction_luts_no_aerosol.tgz

    # 原因下载依赖文件失败
    # 手动下载地址
    win
    pyspectral_rsr_data.tgz 解压放到下面地址
    C:\Users\admin\AppData\Local\pytroll\pyspectral pyspectral_atm_correction_luts_no_aerosol.tgz 解压放到下面地址
    C:\Users\admin\AppData\Local\pytroll\pyspectral\rayleigh_only linux
    pyspectral_rsr_data.tgz 解压放到下面地址
    /root/.local/share/pyspectral pyspectral_atm_correction_luts_no_aerosol.tgz 解压放到下面地址
    /root/.local/share/pyspectral/rayleigh_only
  4. Don't know how to open the following files: {'./FY4A.......HDF'}

    # 按我猜测,应该是satpy 和其依赖包版本的问题
    h5py==3.7.0
    numpy==1.21.6
    satpy==0.36.0
    pyresample==1.22.0
    scikit-image==0.19.3
    pyspectral==0.12.0
  5. 参考地址

    官网:https://satpy.readthedocs.io/en/stable/readers.html#available-readers
    博客:https://cloud.tencent.com/developer/article/1584969牛人:https://github.com/aiwei169/FY4A/blob/main/codes/fy4a.py

satpy 处理卫星 FY4A 数据的更多相关文章

  1. MeteoInfo-Java解析与绘图教程(八)_java解析卫星FY-4A一级产品文件(HDF举例)

    MeteoInfo-Java解析与绘图教程(八)_java解析卫星一级产品文件(HDF举例) 最近解析卫星数据遇到了一级产品,它的解析方式与之前文章说的有些不同,特此补充一下 卫星的一级产品,里面是没 ...

  2. 使用GDAL工具对FY3系列卫星数据进行校正

    本文档主要对如何使用GDAL提供的工具对FY3系列卫星数据进行校正处理.FY3系列卫星提供的数据一般是以HDF5格式下发,一个典型的FY3A和FY3B的数据文件名如下: FY3A_MERSI_GBAL ...

  3. 利用TLE数据确定卫星轨道(1)-卫星轨道和TLE

    1.卫星轨道 太空中卫星和天体在各种引力的作用下都在一定的轨道中周期转动着,但实际的轨道是很复杂的,一般的项目也达不到那么精确的需求(其实精确的卫星参数数据也不可能随便公开的),所以采用一阶近似的开普 ...

  4. PIE SDK打开静止卫星数据

    1. 功能简介 静止卫星是位于地球赤道上空约3.58万km处,与地面始终保持相对静止的卫星,静止卫星的特点是覆盖区域广,具有很强的机动灵活性,能够对特定区域进行分钟级高重复观测,可快速监测灾害目标的动 ...

  5. 使用Geolocation校正GDAL不支持的数据

    对于低分数据来说,常用的校正方式就是给定数据的经纬度查找表来进行校正.在GDAL中,这种校正方式叫Geolocation array.常用的数据有国外的MODIS数据,国内的如风云系列(FY)和海洋系 ...

  6. Cesium专栏-卫星轨迹

    Cesium Cesium 是一款面向三维地球和地图的,世界级的JavaScript开源产品.它提供了基于JavaScript语言的开发包,方便用户快速搭建一款零插件的虚拟地球Web应用,并在性能,精 ...

  7. 全球DEM高程数据下载

    本文主要介绍如何使用“迈高图-地图数据下载器”(以下简称:迈高图)下载全球DEM高程数据,任意下载范围自动拼接.裁剪.DEM高程数据支持下载导出为:GeoTIFF.XYZ.南方CASS等常用数据格式. ...

  8. MeteoInfoLab脚本示例:OMI Swath HDF数据

    这个例子读取OMI卫星Swath数据中的CloudFaction变量并绘图.脚本程序: #Add data file folder = 'D:/Temp/hdf/' fns = 'OMI-Aura_L ...

  9. 蒸腾量与蒸散量(ET)数据、潜在蒸散量、实际蒸散量数据、气温数据、降雨量数据

    ​   数据下载链接:数据下载链接 引言 多种卫星遥感数据反演地表蒸腾与蒸散率(ET)产品是地理遥感生态网推出的生态环境类数据产品之一,产品包括2000-2009年三个波段RGB数据,值域0-252之 ...

  10. 高精度10m/30米NPP净初级生产力分布数据

    数据下载链接:百度云下载链接​ 引言 第一性生产力是绿色植物呼吸后所剩下的单位面积单位时间内所固定的能量或所生产的有机物质,即是总第一性生产量减去植物呼吸作用所剩下的能量或有机物质.多种卫星遥感数据反 ...

随机推荐

  1. 图卷积神经网络分类的pytorch实现

    图神经网络(GNN)目前的主流实现方式就是节点之间的信息汇聚,也就是类似于卷积网络的邻域加权和,比如图卷积网络(GCN).图注意力网络(GAT)等.下面根据GCN的实现原理使用Pytorch张量,和调 ...

  2. 什么是MES(Manufacturing Execution System)

    "本文仅代表个人观点" 本文档将提供一个高层次的概述,以帮助阐明什么是MES,并触及通常被归为MES的周边领域. 整体情况 制造执行系统或MES软件是旨在帮助公司管理其制造过程的工 ...

  3. appium 在linux安装和使用(持续更新)

    appium V1.10 centos7.4 安装 安装步骤 1. 安装node 为了得到npm(node package manager,nodejs的安装包管理工具,可以通过npm来下载appiu ...

  4. ChatGPT API使用介绍

    1.概述 随着人工智能技术的不断发展,越来越多的AI产品被应用到各个领域,其中最具代表性的莫过于人工智能语言模型.语言模型是一种可以通过学习大量语言数据来预测文本或语音的技术,其应用范围十分广泛,如智 ...

  5. sqlite3数据库Linux 系统移植和使用

    sqlite3数据库是一个小型的数据库,当数据量不大,要求不是特别高的时候,是个不错的选择. 在Linux上移植和使用也非常的方便. 本示例是在硬件全志r528 .linux5.4 上验证的. 移植操 ...

  6. ASP和jq实现url传递参数乱码的escape编码和unescape解码

    <% Function vbsEscape(str)    dim i,s,c,a    s=""    For i=1 to Len(str)        c=Mid(s ...

  7. 遗忘的pawn 创建

    默认加载 pawn::staticclass; ConstructorHelpers::FClassFinder<>Pawnpath(TEXT("_C")); 然后是的 ...

  8. 【转载】Python(cx_oracle)的DPI-1047错误

    转自:https://blog.csdn.net/weixin_45158749/article/details/124800132 Python(cx_oracle)的DPI-1047错误 步步 F ...

  9. fiddler的界面详细讲解

    一.fiddler首页概述

  10. Cookie之记录用户上次访问时间

    Cookie之记录用户访问时间 需求: 需求: 1:用户访问服务器(Servlet),判断用户是否是第一次访问,如果是第一次访问,则在页面响应内容为:"您好,欢迎您首次访问"; 2 ...