爱气象,爱气象家园! 

气象家园

 找回密码
 立即注册

QQ登录

只需一步,快速开始

新浪微博登陆

只需一步, 快速开始

搜索
查看: 10061|回复: 7

[求助] linux下运行fortran程序,不知道错在哪里

[复制链接]

新浪微博达人勋

发表于 2012-9-13 16:43:14 | 显示全部楼层 |阅读模式

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

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

x


open(unit=4,file='hgt500hpa.mon.dat',status='old',access='direct',form='unformatted',recl=1085)
read(4,*)
do t=1,nt
do y=1,ny
  do x=1,nx
read(4,*) hgt(x,y,t)
  end do
end do
end do
close(1)


运行后显示错误At line 7 of file season_mean.f90 (unit = 4, file = 'hgt500hpa.mon.dat')
Fortran runtime error: Format present for UNFORMATTED data transfer
我不知道哪里错了,这个格式不能这样读取吗?
请各位帮帮我看看

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

新浪微博达人勋

发表于 2012-9-13 20:50:03 | 显示全部楼层
你应该想直接方式读取无格式文件。首先确定recl的值,这要依据你的记录长度了,然后 read(4,irec)irec代表ith记录。
密码修改失败请联系微信:mofangbao

新浪微博达人勋

 楼主| 发表于 2012-9-14 09:15:05 | 显示全部楼层

嗯嗯,我试试,thank you~
密码修改失败请联系微信:mofangbao

新浪微博达人勋

 楼主| 发表于 2012-9-14 11:08:47 | 显示全部楼层
program one
implicit none
integer,parameter::nx=35,ny=21,nt=776,iyear=63
real,dimension(nx,ny,nt)::hgt
real,dimension(nx,ny,iyear)::hgtwinter
integer::i,j,k,t,irec

open(1,file='hgt500hpa.mon.dat',status='old',form='unformatted',access='direct',recl=35*21)
irec=0
do t=1,nt
irec=irec+1
read(1,rec=irec)((hgt(i,j,t),i=1,nx),j=1,ny)
end do
close(1)

这次出现的错误是I/O past end of record on unformatted file   格点范围肯定都对,我编写了ctl用grads对hgt500hpa.mon.dat'画过图的,这个错误是说我数组越界吗? 这个dat是用grads从nc文件转过来的,到底是无格式的还是有格式的。。。好纠结,好烦,求帮助
密码修改失败请联系微信:mofangbao

新浪微博达人勋

发表于 2012-9-17 10:33:12 | 显示全部楼层
xiaohundanpipi 发表于 2012-9-14 11:08
program one
implicit none
integer,parameter::nx=35,ny=21,nt=776,iyear=63

给我看你的文件,xucp11@lzu.edu.cn
密码修改失败请联系微信:mofangbao

新浪微博达人勋

 楼主| 发表于 2012-9-17 14:43:40 | 显示全部楼层
bustop 发表于 2012-9-17 10:33
给我看你的文件,

你好,程序已经给你发过去了。
我换到xp上运行了一下,程序就对了,不知道到底是不是linux有什么特殊的要求
这是我求季平均的fortran程序,大家共勉。
program one
implicit none
integer,parameter::nx=35,ny=21,nt=776,iyear=64
real,dimension(nx,ny,nt)::hgt
real,dimension(nx,ny,iyear)::hgtwinter
integer::i,j,k,t,irec



open(1,file='hgt500hpa.mon.dat',status='old',form='unformatted',access='direct',recl=35*21)
do t=1,nt
  read(1,rec=t)(( hgt(i,j,t),i=1,nx),j=1,ny)      
end do
close(1)
print*,hgt(35,21,776)


do j=1,ny
  do i=1,nx
    do t=12,770,12
          if (hgt(i,j,t)/=-9.96921e+36 .and. hgt(i,j,t+1)/=-9.96921e+36 .and.hgt(i,j,t+2)/=-9.96921e+36) then
         hgtwinter(i,j,(t-12)/12+1)=-9.96921e+36
          else
         hgtwinter(i,j,(t-12)/12+1)=(hgt(i,j,t)+hgt(i,j,t+1)+hgt(i,j,t+2))/3
          end if
    end do
  end do
end do


print*,hgtwinter(30,2,:)

open(2,file='hgtwinter.mean.dat',status='replace',form='unformatted',access='direct',recl=35*21)
irec=0
do t=1,64
irec=irec+1
write(2,rec=irec)((hgtwinter(i,j,t),i=1,nx),j=1,ny)
end do
close(2)
print*,'zz'

end program one



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

新浪微博达人勋

发表于 2012-9-17 16:46:47 | 显示全部楼层
xiaohundanpipi 发表于 2012-9-17 14:43
你好,程序已经给你发过去了。
我换到xp上运行了一下,程序就对了,不知道到底是不是linux有什么特殊的要 ...

我也试了的确不能linux,但将recl改成35*21*4就可以。这是因为xp系统同linux系统编译器处理数据的位数不同导致。若还有问题,发送我邮箱。
密码修改失败请联系微信:mofangbao

新浪微博达人勋

 楼主| 发表于 2012-9-18 14:30:05 | 显示全部楼层
bustop 发表于 2012-9-17 16:46
我也试了的确不能linux,但将recl改成35*21*4就可以。这是因为xp系统同linux系统编译器处理数据的位数不同 ...

嗯嗯 谢谢啦。。。你真是个好人~
密码修改失败请联系微信:mofangbao
您需要登录后才可以回帖 登录 | 立即注册 新浪微博登陆

本版积分规则

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

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

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