当前位置: 首页 > news >正文

Matlab代码批处理中国地面气象日值数据集(2400站点数据集),提取所需省份全部站点数据

       气象数据一直是一个价值较高的数据,它被广泛用于各个领域的研究当中。地理遥感生态网平台提供的气象数据包括有气温、气压、相对湿度、降水、蒸发、风向风速、日照等多种指标,但是包含了这些全部指标的气象数据却较难获取,即使获取到了也不能随意分享。

1级目录

文件名

PRS

SURF_CLI_CHN_MUL_DAY-PRS-10004-YYYYMM.TXT(本站气压)

TEM

SURF_CLI_CHN_MUL_DAY-TEM-12001-YYYYMM.TXT(气温)

RHU

SURF_CLI_CHN_MUL_DAY-RHU-13003-YYYYMM.TXT(相对湿度)

PRE

SURF_CLI_CHN_MUL_DAY-PRE-13011-YYYYMM.TXT(降水)

EVP

SURF_CLI_CHN_MUL_DAY-EVP-13240-YYYYMM.TXT(蒸发)

WIN

SURF_CLI_CHN_MUL_DAY-WIN-11002-YYYYMM.TXT(风向风速)

SSD

SURF_CLI_CHN_MUL_DAY-SSD-14032-YYYYMM.TXT(日照)

GST

SURF_CLI_CHN_MUL_DAY-GST-12030-0cm-YYYYMM.TXT(0cm地温)

     Matlab:中国地面气象日值数据集提取所需省份全部站点数据
代码结构:
(1)Input:8个变量,每年12个月,每年96个txt文件;
(2)目标:多年循环,提取所需站点;
(3)Output:一个子变量一个表,全年数据放入一个sheet中,不同年份放入不同sheet中
输入数据命名基本为默认:

%%%%
% @LastEditors  : 地理遥感生态网平台 
% @Date         : 2021-12-01 20:00 
% @LastEditTime : 2021-12-07 22:00 
% @Description  : 全系列标准化气象数据的处理txt2excel;注意对每个输出结果进行检查
% @Objective    : 按类输出所需省份全部年份n个气象站点数据
%%
clear;
clc;
%% 0. 前期输入输出&定义
% 输入txt根路径
txt_Path='D:\科研数据\metadata\2010_2017\';
% 输出xls根路径
xls_Path='D:\科研数据\metadata\xls2010_2017\';
% 预分配中间变量内存,列数根据元数据类别数目确定(注意按需修改)
A11=zeros(68,11);%3 RHU相对湿度;5 EVP蒸发;
% 按年读取全部txt文件
% year by year
for yy = 2010:2017
    year = num2str(yy);
    txt_file=fullfile(txt_Path,year,'\');    
    txt_list=dir(strcat(txt_file,'*.txt'));%列出路径下所有txt文件
% 判别平闰年,确定月天数,计算doy     
    if (mod(yy,4)==0 && mod(yy,100)~=0 || mod(yy,400)==0)
    mon2day=[31 29 31 30 31 30 31 31 30 31 30 31]; % 闰年各月天数
    else
    mon2day=[31 28 31 30 31 30 31 31 30 31 30 31]; % 平年各月天数
    end 
    doy=sum(mon2day);
% 根据doy预分配输出数据和表头(注意按需修改)    
    evp_d20=zeros(66,4+doy);
    evp_E601=zeros(66,4+doy);

    title{1,1}='station';
    title{1,2}='lat';
    title{1,3}='lon';
    title{1,4}='altitude';
    for dd=1:doy
        title{1,4+dd}=strcat('doy',year,num2str(dd,'%03d'));
    end
%% 1. 集成EVP结果
% month by month
i=1;
m=1;%第1个变量,排序根据txt_list来确定
m1=1+12*(m-1);%每个变量的第1个txt
m0=12*(m-1);
m12=12*m;%每个变量的第12个txt
for mm=m1:m12
    evp_name=txt_list(mm).name;
    evp_mm=load(fullfile(txt_file,evp_name));%原始txt文件读成表
    n=1;
    ss_1=53*mon2day(mm-m0)+1;%51053第1天
    ss_2=(53+68-1)*mon2day(mm-m0)+1;%52313第1天
% day by day
    for dm=0:(mon2day(mm-m0)-1)%1个月每天的循环
        for ss=(ss_1+dm):mon2day(mm-m0):(ss_2+dm)%68个站点提取同一天
            A11(n,:)=evp_mm(ss,:);
            n=n+1;
        end
        A11(61,:)=[];% delete 51886	剔除不需要的站点
        A11(66,:)=[];% delete 52267	注意上一个删除后位次67需减去1
        evp_d20(:,1:3)=A11(1:66,1:3);
        evp_E601(:,1:3)=A11(1:66,1:3);

        evp_d20(:,4)=A11(1:66,4)*0.1;%altitude,0.1米
        evp_E601(:,4)=A11(1:66,4)*0.1;%altitude,0.1米

        evp_d20(:,4+i)=A11(:,8)*0.1;%小型蒸发量,0.1mm
        evp_E601(:,4+i)=A11(:,9)*0.1;%大型蒸发量,0.1mm      
        i=i+1;
        clear A11;
        n=1;     
    end
end
% 经纬单位(度、分),转换为度
lat_int=floor(evp_d20(:,2)*0.01);
lat_decimal=(evp_d20(:,2)*0.01-lat_int).*100/60;
lat=lat_int+lat_decimal;

lon_int=floor(evp_d20(:,3)*0.01);
lon_decimal=(evp_d20(:,3)*0.01-lon_int).*100/60;
lon=lon_int+lon_decimal;

evp_d20(:,2)=lat;
evp_E601(:,2)=lat;

evp_d20(:,3)=lon;
evp_E601(:,3)=lon;

% 质量控制,剔除异常值(matlab固有bug,查找替换不完全,采用excel查找替换)
% evp_d20(evp_d20(:,5:end)==evp_d20(1,274))=nan;
% % evp_d20(evp_d20(:,5:end)>32765)=nan;
% evp_E601(evp_E601(:,5:end)==evp_E601(1,5))=nan;
% check1=find(evp_d20==3276.6);
% check2=find(evp_E601==3276.6);

% 输出,sheet名改为年份,所有年份,全年存在一个excel表中
writecell(title,strcat(xls_Path,'EVP_d20.xlsx'),'Sheet',year,'Range','A1');
writematrix(evp_d20,strcat(xls_Path,'EVP_d20.xlsx'),'Sheet',year,'Range','A2');

writecell(title,strcat(xls_Path,'EVP_E601.xlsx'),'Sheet',year,'Range','A1');
writematrix(evp_d20,strcat(xls_Path,'EVP_E601.xlsx'),'Sheet',year,'Range','A2');
clear doy title;
end

        通过这样就可以得到逐年的所需站点的数据集了,方便又快捷!如果对您有帮助的话请点赞转发支持下!

   赶紧三连关注下, 数据获取途径如下:

相关文章:

  • 链表之头指针、头结点、首元结点、空链表
  • 【Linux】静态库与共享库
  • POI入门
  • 07- 诊断事件diagnostic events的类图关系
  • 【C#】RestSharp踩坑日记
  • 自学5个月软件测试找到一个8k的工作,我的学习方式值得你借鉴
  • 【JavaEE初阶】文件操作 和 IO (下篇)
  • Nebula Studio:部署与连接
  • Redis 学习笔记
  • 萤火虫(FA)算法(附完整Matlab代码,可直接复制)
  • 01背包完全背包学习记录
  • docker安装redis
  • java毕业设计的婚庆策划系统的设计与实现mybatis+源码+调试部署+系统+数据库+lw
  • Pandas数据分析:处理文本数据(str/object)各类操作+代码一文详解(二)
  • java毕业设计的家居销售网站mybatis+源码+调试部署+系统+数据库+lw
  • 【翻译】Mashape是如何管理15000个API和微服务的(三)
  • C++回声服务器_9-epoll边缘触发模式版本服务器
  • django开发-定时任务的使用
  • passportjs 源码分析
  • vue-loader 源码解析系列之 selector
  • Webpack 4x 之路 ( 四 )
  • weex踩坑之旅第一弹 ~ 搭建具有入口文件的weex脚手架
  • 从地狱到天堂,Node 回调向 async/await 转变
  • 对JS继承的一点思考
  • 机器学习中为什么要做归一化normalization
  • 跨域
  • 你不可错过的前端面试题(一)
  • 爬虫模拟登陆 SegmentFault
  • 前端设计模式
  • 让你成为前端,后端或全栈开发程序员的进阶指南,一门学到老的技术
  • 实现菜单下拉伸展折叠效果demo
  • 听说你叫Java(二)–Servlet请求
  • 微信如何实现自动跳转到用其他浏览器打开指定页面下载APP
  • 原创:新手布局福音!微信小程序使用flex的一些基础样式属性(一)
  • 带你开发类似Pokemon Go的AR游戏
  • ​​​​​​​Installing ROS on the Raspberry Pi
  • (10)Linux冯诺依曼结构操作系统的再次理解
  • (51单片机)第五章-A/D和D/A工作原理-A/D
  • (PHP)设置修改 Apache 文件根目录 (Document Root)(转帖)
  • (附源码)spring boot智能服药提醒app 毕业设计 102151
  • (机器学习的矩阵)(向量、矩阵与多元线性回归)
  • (九)One-Wire总线-DS18B20
  • (九)信息融合方式简介
  • (一)使用IDEA创建Maven项目和Maven使用入门(配图详解)
  • .Net Attribute详解(上)-Attribute本质以及一个简单示例
  • .NET Project Open Day(2011.11.13)
  • .NET 命令行参数包含应用程序路径吗?
  • .NET 中让 Task 支持带超时的异步等待
  • .NET/C# 利用 Walterlv.WeakEvents 高性能地定义和使用弱事件
  • .Net8 Blazor 尝鲜
  • .vollhavhelp-V-XXXXXXXX勒索病毒的最新威胁:如何恢复您的数据?
  • .xml 下拉列表_RecyclerView嵌套recyclerview实现二级下拉列表,包含自定义IOS对话框...
  • @param注解什么意思_9000字,通俗易懂的讲解下Java注解
  • @ResponseBody
  • [1127]图形打印 sdutOJ