爱气象,爱气象家园! 

气象家园

 找回密码
 立即注册

QQ登录

只需一步,快速开始

新浪微博登陆

只需一步, 快速开始

搜索
查看: 13258|回复: 18

[源代码] fortran生成二进制数据(.dat)之后自动生成ctl文件

[复制链接]

新浪微博达人勋

发表于 2014-12-12 15:54:43 | 显示全部楼层 |阅读模式

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

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

x
本帖最后由 虫儿飞 于 2014-12-12 16:01 编辑

先给程序
subroutine generate_ctl(data_name_str,xdef_str,ydef_str,zdef_str,tdef_str,vars,var)
implicit none

character*150 :: data_name_str,title_str
character*100 :: xdef_str,ydef_str,zdef_str,tdef_str
integer*4 :: vars
character*1 :: vars_str
character*100 :: var(vars)
character*150 :: out_file_str
character*25, parameter :: path_str = '**************************'
integer*4 :: i
out_file_str = trim(data_name_str)//'.ctl'
open(1001,file=trim(path_str)//trim(out_file_str))
    title_str = data_name_str
    call sub_replace_character(title_str,'.',' ')
write(vars_str,'(i1)')vars
write(1001,'(a)') adjustl('dset '//trim(path_str)//trim(data_name_str)//'.dat')
write(1001,'(a)') adjustl('undef -9.99E+08')
write(1001,'(a)') adjustl('title '//trim(title_str))
  write(1001,'(a)') adjustl(xdef_str)
write(1001,'(a)') adjustl(ydef_str)
write(1001,'(a)') adjustl(zdef_str)
write(1001,'(a)') adjustl(tdef_str)
write(1001,'(a)') adjustl('vars '//trim(vars_str))
do i = 1,vars
write(1001,'(a)') adjustl(var(i))
enddo
write(1001,'(a)') adjustl('endvars')
close(1001)
    end

    subroutine sub_replace_character(OutStr,OldChar,NewChar)
        !!!---   说明:InStr是从非‘空格’字符开始的,对于其余三个变量没有要求
        implicit none
        character(len=*) :: OutStr
        character(len=*) :: OldChar,NewChar
        character*150 :: InStr
        integer*4 :: AllCount,SubCountOld,SubCountNew,Count
        integer*4 :: i
        InStr = OutStr
        OutStr = ''
        AllCount = len_trim(InStr)
        SubCountOld = len(OldChar)
        SubCountNew = len(NewChar)
        if(InStr(1:SubCountOld).eq.OldChar) then
            OutStr(1:SubCountNew) = NewChar
            Count = SubCountNew
            i = 1+SubCountOld
        else
            OutStr(1:1) = InStr(1:1)
            Count = 1
            i = 2
        endif
        do while(i.le.AllCount-SubCountOld+1)
            if(InStr(i:i+SubCountOld-1).eq.OldChar) then
                OutStr = OutStr(1:count)//NewChar
                Count = Count + SubCountNew
                i = i+SubCountOld
            else
                OutStr = OutStr(1:Count)//InStr(i:i)
                Count = Count + 1
                i = i+1
            endif
        enddo
        if(i.le.AllCount) OutStr = OutStr(1:Count)//InStr(i:AllCount)
    end

再给示例用法
变量定义阶段
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!   ctl
  character*150  :: data_name_str
  character*100  :: xdef_str,ydef_str,zdef_str,tdef_str
  integer*4   :: vars
  character*100,allocatable :: var(:)
  !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!   ctl
程序调用阶段
out_file_str = 'corr.between.sst.index.of.key.area.and.hgt.dat'
  open(100,file=trim(out_file_str),form='unformatted',access='direct',recl=4*lats*lons)
  irec = 0
  do k = 1,m
   irec = irec + 1
   write(100,rec=irec) ((rr(i,j,k),i=1,lons),j=1,lats)
  enddo
  close(100)
  
  vars = 1
  allocate(var(vars))
  var(1) = 'cc 0 99 correlation coefficient'
  data_name_str = 'corr.between.sst.index.of.key.area.and.hgt'
  xdef_str = 'xdef 144 linear 0 2.5'
  ydef_str = 'ydef 73 linear -90.0 2.5'
  zdef_str = 'zdef 1 linear 0 1'
  tdef_str = 'tdef 13 linear 01Jan1981 1mon'
  call generate_ctl(data_name_str,xdef_str,ydef_str,zdef_str,tdef_str,vars,var)
  deallocate(var)

经过我自己长达2-3年的实践检验,没有问题。
但是有一个细节需要注意,需要在subroutine generate_ctl里修改路径
character*25, parameter :: path_str = '**************************'
一般而言数据在哪儿,ctl就在哪儿,也可以不一样,只要脑袋转得过弯来。

在我的示例中,可以看出我生成的文件名,一般都可以根据名字把这个文件表征的大致内容看出来,并且用圆点想链接,在subroutine generate_ctl里将圆点换成空格,作为数据名称。这个是第二个子程序的用途。




评分

参与人数 2金钱 +30 贡献 +9 体力 +40 收起 理由
言深深 + 20 + 5 + 40 赞一个!
又是那隻貓 + 10 + 4 很给力!

查看全部评分

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

新浪微博达人勋

发表于 2014-12-12 15:59:15 | 显示全部楼层
没说错的话  你这个应该是国家气象局的服务器上的程序   确定可以公开?
密码修改失败请联系微信:mofangbao

新浪微博达人勋

 楼主| 发表于 2014-12-12 16:00:21 | 显示全部楼层
火_旦 发表于 2014-12-12 15:59
没说错的话  你这个应该是国家气象局的服务器上的程序   确定可以公开?

我自己写的程序 还有问题?
密码修改失败请联系微信:mofangbao

新浪微博达人勋

发表于 2014-12-12 16:02:46 | 显示全部楼层
虫儿飞 发表于 2014-12-12 16:00
我自己写的程序 还有问题?

那就谢谢楼主了  看到你的路径都是国家局服务器上的统一路径
密码修改失败请联系微信:mofangbao

新浪微博达人勋

发表于 2014-12-12 16:03:46 | 显示全部楼层
@言深深
密码修改失败请联系微信:mofangbao
回复

使用道具 举报

新浪微博达人勋

 楼主| 发表于 2014-12-12 16:04:28 | 显示全部楼层
火_旦 发表于 2014-12-12 16:02
那就谢谢楼主了  看到你的路径都是国家局服务器上的统一路径

我目前还是学生 用老师的账号在服务器上干活的
密码修改失败请联系微信:mofangbao

新浪微博达人勋

发表于 2014-12-12 16:51:48 | 显示全部楼层
谢谢楼主分享,好东西。楼主有没有想过把这个生成ctl的子程序写的再方便一点?这样的话每次写程序还是要改好多的地方,如果能从output的文件信息中获取一些变量让它自己改就更完美了。
密码修改失败请联系微信:mofangbao

新浪微博达人勋

 楼主| 发表于 2014-12-12 17:29:59 | 显示全部楼层
marclevoy 发表于 2014-12-12 16:51
谢谢楼主分享,好东西。楼主有没有想过把这个生成ctl的子程序写的再方便一点?这样的话每次写程序还是要改 ...

我这样已经很满足了 再智能就要加太多东西了 对我来说不是一个好的选择 这些东西总的来说还是为我的科研服务 我是因为我的结果大多以二进制形式存储 画图必须要ctl  虽然可以根据 已有的进行改造 还是很麻烦 主要是太多了 所以我想着写一个 只要给一点信息就能写ctl的程序 可以减少很大一部分工作量 而且能减少错误 谁能保证根据已有的ctl写新的不会出点错
密码修改失败请联系微信:mofangbao

新浪微博达人勋

发表于 2014-12-12 17:42:03 | 显示全部楼层
楼主好厉害
密码修改失败请联系微信:mofangbao

新浪微博达人勋

发表于 2014-12-12 20:17:54 | 显示全部楼层
谢谢楼主分享!!!
密码修改失败请联系微信:mofangbao
您需要登录后才可以回帖 登录 | 立即注册 新浪微博登陆

本版积分规则

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

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

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