ERA5数据下载的那些事

2024-02-12 11:20
文章标签 数据 下载 era5

本文主要是介绍ERA5数据下载的那些事,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

ERA5数据下载那些事

  • 基本操作
  • 常见问题汇总
  • 资源分享

基本操作

近年做的数据处理都是气象气候数据,最近需要处理ERA5的suface data(以下简称2D数据)和pressure level data(以下简称3D数据),第一个碰到的问题就是下载数据的问题。
数据下载方案初步设计有三:

  1. 租国外的服务器,起码2T的内存,从国外服务器传到国内的服务器,最后转存到大型机
  2. 分任务利用同事的机子和账号并行下,下载数据用CDS提供的镜像(copernicus-climate.eu)
  3. 分任务利用同事的机子和账号并行下,下载数据切换成国内的镜像(nuist.love)
    先来对比一下3种方法的优缺点:
方法编号优点缺点
1国外网速快传到国内机器网速就一般了,1M/s左右,最重要是要花钱,排队时间是否有地区差异,这个暂时不明
2分而治之,并行下载,原生的镜像支持断点续传,可以自动retry直到最大次数为止排队时间长,要有人写分批下载脚本,统一管理,总得来说废人力,少废钱
3分而治之,并行下载,国内镜像以为会快一点,但优势胜在小文件缺点和方法2是一样的,网速的提升也适用于小文件,网络不能中断,不支持断点续传,大文件显然就不是很合适

鉴于经费,直接排除了第一种,租国外服务器的方法,这种费钱也不见得快多少的方法,肯定是被领导排除的。最后我选择了第二种,因为断点续传,对大文件(现在基本上30G一个文件)来说是很必要的。再说一下我为什么要一次提交这么多 ,我注册的账号在国内,排队的时间很长,而任务提交需要经过 queue-> in progress->download的过程,所以每次提交的一次计算的量大点会划算一点,这里需要说明的是,每次提交的计算量最多12万item,怎么样看自己想要计算的item到底有多少,可以直接在(下载官网页面),选择要下载的数据的参数,如果超过12万个item,页面最下方有显示,如下图所示:
在这里插入图片描述
反过来要是没有这个提示,就可以大大方方下载。
测试下来,3d变量一年得分2个,上半年一个,下半年一个,2D变量是10年一个,1991-2021分3个下载。

PS:大家且看看,快速实现的,没有全部函数通用化,用的时候可自行修改!!!
生成好的目录结构和脚本大概是这样:
在这里插入图片描述

现在把数据下载放在dataset目录下,对所有down开头和py结尾的下载文件都支持,然后这个下载脚本放在dataset同级目录即可执行,本脚本假如下载的文件不完整的话,会打印文件名。
只要算好可用内存,在dataset目录下就放几个下载任务,晚上下载,白天拷贝,隔两天上传大型机。

常见问题汇总

  1. 问题1:.cdsapirc这个文件里面的内容设置错误,简单的下载代码都会出现tuple is not callable
    解答:其实在添加链接描述已经有详细的cds api使用描述,一步步走下来,唯一有疑惑的点就是.cdsapirc文件里面放什么,放在哪里。这里直接给出答案,登录上述链接,黑框框里就是自己.cdsapirc的内容了,不需要根据自己的key做拼接。还有就是这个文件放哪里,我在windows下直接放在c盘,Users目录下的当前用户目录下,即C:\Users\当前用户名.cdsapirc,如果是linux目录那就打印 $HOME,然后放到这个目录下就可以了。

  2. 问题2:下载ERA5的数据,其实是想要daily数据的,官网也提供了一个获取这些统计量的页面,也提供了脚本下载的接口代码,奈何,只能以月为单位,如果要下载多年的话,得循环提交多次,这样就导致了任务多,排队时间长,听说提交多请求会被限制,所以得不偿失。
    解答:官方给出的原话是:
    在这里插入图片描述
    is limited to 和 for efficiency就已经框死了,所以加速无望,只能是下载原始的hourly数据,自己算。下载的数据的时候要把一天24个时刻的数据都选上,而不是选几个所谓的代表性的,去代表这一天。

  3. 问题3:如果数据中断之后,怎么下载
    解答:正常情况下我们会打开一个cmd窗口,提交自己批处理的脚本,在下载过程中,输出的文件名就是没有下载完整的,然后我们可以根据这个文件名,找到同目录运行的log,log名与脚本名相同,在log里面给出了数据链接,可以手动复制到迅雷下载里面补算。
    在这里插入图片描述

资源分享

  1. 获取ERA5统计数据的地址

  2. total precipitation计算参考地址

  3. 用python代码计算total precipitation参考地址

  4. 2米温度计算T2MAX、T2MIN说明参考地址

这篇关于ERA5数据下载的那些事的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/702488

相关文章

Java下载文件中文文件名乱码的解决方案(文件名包含很多%)

《Java下载文件中文文件名乱码的解决方案(文件名包含很多%)》Java下载文件时,文件名中文乱码问题通常是由于编码不正确导致的,使用`URLEncoder.encode(filepath,UTF-8... 目录Java下载文件中文文件名乱码问题一般情况下,大家都是这样为了解决这个问题最终解决总结Java下

Redis的数据过期策略和数据淘汰策略

《Redis的数据过期策略和数据淘汰策略》本文主要介绍了Redis的数据过期策略和数据淘汰策略,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录一、数据过期策略1、惰性删除2、定期删除二、数据淘汰策略1、数据淘汰策略概念2、8种数据淘汰策略

轻松上手MYSQL之JSON函数实现高效数据查询与操作

《轻松上手MYSQL之JSON函数实现高效数据查询与操作》:本文主要介绍轻松上手MYSQL之JSON函数实现高效数据查询与操作的相关资料,MySQL提供了多个JSON函数,用于处理和查询JSON数... 目录一、jsON_EXTRACT 提取指定数据二、JSON_UNQUOTE 取消双引号三、JSON_KE

Python给Excel写入数据的四种方法小结

《Python给Excel写入数据的四种方法小结》本文主要介绍了Python给Excel写入数据的四种方法小结,包含openpyxl库、xlsxwriter库、pandas库和win32com库,具有... 目录1. 使用 openpyxl 库2. 使用 xlsxwriter 库3. 使用 pandas 库

SpringBoot定制JSON响应数据的实现

《SpringBoot定制JSON响应数据的实现》本文主要介绍了SpringBoot定制JSON响应数据的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们... 目录前言一、如何使用@jsonView这个注解?二、应用场景三、实战案例注解方式编程方式总结 前言

使用Python在Excel中创建和取消数据分组

《使用Python在Excel中创建和取消数据分组》Excel中的分组是一种通过添加层级结构将相邻行或列组织在一起的功能,当分组完成后,用户可以通过折叠或展开数据组来简化数据视图,这篇博客将介绍如何使... 目录引言使用工具python在Excel中创建行和列分组Python在Excel中创建嵌套分组Pyt

在Rust中要用Struct和Enum组织数据的原因解析

《在Rust中要用Struct和Enum组织数据的原因解析》在Rust中,Struct和Enum是组织数据的核心工具,Struct用于将相关字段封装为单一实体,便于管理和扩展,Enum用于明确定义所有... 目录为什么在Rust中要用Struct和Enum组织数据?一、使用struct组织数据:将相关字段绑

在Mysql环境下对数据进行增删改查的操作方法

《在Mysql环境下对数据进行增删改查的操作方法》本文介绍了在MySQL环境下对数据进行增删改查的基本操作,包括插入数据、修改数据、删除数据、数据查询(基本查询、连接查询、聚合函数查询、子查询)等,并... 目录一、插入数据:二、修改数据:三、删除数据:1、delete from 表名;2、truncate

Java实现Elasticsearch查询当前索引全部数据的完整代码

《Java实现Elasticsearch查询当前索引全部数据的完整代码》:本文主要介绍如何在Java中实现查询Elasticsearch索引中指定条件下的全部数据,通过设置滚动查询参数(scrol... 目录需求背景通常情况Java 实现查询 Elasticsearch 全部数据写在最后需求背景通常情况下

Python实现文件下载、Cookie以及重定向的方法代码

《Python实现文件下载、Cookie以及重定向的方法代码》本文主要介绍了如何使用Python的requests模块进行网络请求操作,涵盖了从文件下载、Cookie处理到重定向与历史请求等多个方面,... 目录前言一、下载网络文件(一)基本步骤(二)分段下载大文件(三)常见问题二、requests模块处理