爱气象,爱气象家园! 

气象家园

 找回密码
 立即注册

QQ登录

只需一步,快速开始

新浪微博登陆

只需一步, 快速开始

搜索
查看: 3791|回复: 8

[分享资料] 160站降水生成map文件时发生这样的错误

[复制链接]

新浪微博达人勋

发表于 2013-11-28 20:31:38 | 显示全部楼层 |阅读模式

登录后查看更多精彩内容~

您需要 登录 才可以下载或查看,没有帐号?立即注册 新浪微博登陆

x
原文件是在气候中心上下载的txt形式,月平均的降水,总共63年。
做完fortran程序转为dat格式:
program preci
parameter(sta=160,tt=63)
integer d(sta,tt),a(tt,sta),nlev,flag
real lon(sta),lat(sta),tim
character*8 stid(sta)
open(11,file='F:\graduate\work\data\station.txt')
open(22,file='F:\graduate\work\data\1.txt')
open(33,file='F:\graduate\sta.dat',status='replace',form='binary')

do i=1,sta
        read(11,*) stid(i),lon(i),lat(i)
enddo

do i=1,160
stid(i)=char(i)
end do

read(22,*) ((d(i,j),i=1,sta),j=1,tt)

a=transpose(d) !对原降水序列进行转置,使行为时次(外循环),列为站名(内循环,空间)

do i=1,tt
tim=0.0
nlev=1
flag=1
        do j=1,sta
                write(33)stid(j),lon(j),lat(j),tim,nlev,flag,a(i,j)
        enddo
nlev=0
write(33)stid(sta),lon(sta),lat(sta),tim,nlev,flag   
!print*, stid(sta),lon(sta),lat(sta),tim,nlev,flag
enddo
close(33)
close(22)
close(11)
end


然后是ctl:
DSET   e:/160/sta.dat
DTYPE  station   
STNMAP e:/160/data_sample.map
UNDEF  -999.0  
TITLE  Station Data Sample  
TDEF   756 linear 01jan1951 1mo
VARS 1  
rain    0  99  rainfall data of 160station
endvars


最后运行ctl时发生的错误是,查了一下,此处的EOF意为:end of file
捕获.PNG
还请各位多多帮忙了!我是新手,按着清风写的套路做的,翻来覆去也没看出问题!
密码修改失败请联系微信:mofangbao

新浪微博达人勋

发表于 2013-11-28 22:21:11 | 显示全部楼层
lat在前,lon在后。改一下试试吧
密码修改失败请联系微信:mofangbao

新浪微博达人勋

 楼主| 发表于 2013-11-28 22:31:18 | 显示全部楼层

我确实把经纬度搞错了,不过改完还是一样的问题。
在fortran中试着在屏幕上输出也没有问题,请问您觉得可能是什么原因?
密码修改失败请联系微信:mofangbao

新浪微博达人勋

发表于 2013-11-29 00:34:17 | 显示全部楼层
本帖最后由 linikiku 于 2013-11-29 00:39 编辑

把 这句 write(33)stid(sta),lon(sta),lat(sta),tim,nlev,flag
改成 write(33) stid(j-1),lat(j-1),lon(j-1),tim,nlev,flag

试一试。
密码修改失败请联系微信:mofangbao

新浪微博达人勋

发表于 2013-11-29 08:22:35 | 显示全部楼层
好猫 发表于 2013-11-28 22:31
我确实把经纬度搞错了,不过改完还是一样的问题。
在fortran中试着在屏幕上输出也没有问题,请问您觉得可 ...

tim=0.0
nlev=1
flag=1
这几句应该放在循环里面的吧,就是放在时间和站点循环的最里面
密码修改失败请联系微信:mofangbao

新浪微博达人勋

 楼主| 发表于 2013-11-29 09:09:39 | 显示全部楼层
linikiku 发表于 2013-11-29 00:34
把 这句 write(33)stid(sta),lon(sta),lat(sta),tim,nlev,flag
改成 write(33) stid(j-1),lat(j-1),lon(j ...

找到问题了!原来是我只处理的63年每年一月的数据,所以ctl文件的时次应该是63而不是756!
还是谢谢了!
密码修改失败请联系微信:mofangbao

新浪微博达人勋

 楼主| 发表于 2013-11-29 09:10:02 | 显示全部楼层
river 发表于 2013-11-29 08:22
tim=0.0
nlev=1
flag=1

找到问题了!原来是我只处理的63年每年一月的数据,所以ctl文件的时次应该是63而不是756!
还是谢谢了!以后真的要细心!
密码修改失败请联系微信:mofangbao

新浪微博达人勋

发表于 2015-3-23 11:56:54 | 显示全部楼层
为什么要进行转制呢?
密码修改失败请联系微信:mofangbao

新浪微博达人勋

发表于 2018-1-18 09:11:37 | 显示全部楼层
请问map文件如何生成
密码修改失败请联系微信:mofangbao
您需要登录后才可以回帖 登录 | 立即注册 新浪微博登陆

本版积分规则

Copyright ©2011-2014 bbs.06climate.com All Rights Reserved.  Powered by Discuz! (京ICP-10201084)

本站信息均由会员发表,不代表气象家园立场,禁止在本站发表与国家法律相抵触言论

快速回复 返回顶部 返回列表