爱气象,爱气象家园! 

气象家园

 找回密码
 立即注册

QQ登录

只需一步,快速开始

新浪微博登陆

只需一步, 快速开始

搜索
查看: 19710|回复: 22

把NCL算出来的值写入txt文件

[复制链接]

新浪微博达人勋

发表于 2014-4-23 10:57:07 | 显示全部楼层 |阅读模式
NCL
系统平台:
问题截图: -
问题概况: 算出来了各个时间段的最大值,想把对应的时间和最大值写入另一个文件,比如txt,然后用origin画时间序列图。
我看过提问的智慧: 看过
自己思考时长(天): 1

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

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

x
算出来了各个时间段的最大值,想把对应的时间和最大值写入另一个文件,比如txt,然后用origin画时间序列图。    if(isfilevar(a,"QICE"))
      qi = wrf_user_getvar(a,"QICE",it)
      qi = qi*1000.
      qi@units = "g/kg"   
    end if
    max = max(qi)

但是官网上好像只有写入ascii和nc文件的例子。
asciiwrite(ascii_file,temp(7:3:2,0:4))
请问大家有没有把数据写入过txt之类的,我们可以打开并且可以看到数据的文件
请指点一二
密码修改失败请联系微信:mofangbao

新浪微博达人勋

发表于 2014-4-23 12:20:09 | 显示全部楼层
ascii是一种编码类型,txt仅仅是一个文件后缀名,两者不是同一回事。txt可以有多种编码,ascii也是其中之一。所以,ncl官网上有关写ascii文件的例子都能满足你的要求。
密码修改失败请联系微信:mofangbao

新浪微博达人勋

发表于 2014-4-23 13:25:37 | 显示全部楼层
黄小仙儿,你牛人啊,grads、ncl、meteoinfo、origin、python、fortran你同时来啊!o(∩∩)o...哈哈。
密码修改失败请联系微信:mofangbao

新浪微博达人勋

发表于 2014-4-23 13:46:54 | 显示全部楼层
asciiwrite("*.txt",data)不就行了,另外你可以试试ascii_table ,ascii_matrix
密码修改失败请联系微信:mofangbao

新浪微博达人勋

 楼主| 发表于 2014-4-23 15:07:04 | 显示全部楼层
longlivehj 发表于 2014-4-23 13:25
黄小仙儿,你牛人啊,grads、ncl、meteoinfo、origin、python、fortran你同时来啊!o(∩∩)o...哈哈。

因为太菜了,什么都做不好啊~
密码修改失败请联系微信:mofangbao

新浪微博达人勋

 楼主| 发表于 2014-4-23 16:06:23 | 显示全部楼层
askira2011 发表于 2014-4-23 13:46
asciiwrite("*.txt",data)不就行了,另外你可以试试ascii_table ,ascii_matrix

我试着改了下,但是好像循环有问题,出来的txt只有一个数值
do it =0, ntimes-1,1        ; TIME LOOP

    print("Working on time: " + times(it) )
    res@TimeLabel = times(it)   ; Set Valid time to use on plots

;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
; First get the variables we will need        
    if(isfilevar(a,"QICE"))
      qi = wrf_user_getvar(a,"QICE",it)
      qi = qi*1000.
      qi@units = "g/kg"   
    end if
    wmax = max(qi)
        print(wmax)
ascii_file = "data.txt"
asciiwrite(ascii_file, sprintf("%12.8f", wmax ))
end do
密码修改失败请联系微信:mofangbao

新浪微博达人勋

 楼主| 发表于 2014-4-23 16:06:54 | 显示全部楼层
longlivehj 发表于 2014-4-23 13:25
黄小仙儿,你牛人啊,grads、ncl、meteoinfo、origin、python、fortran你同时来啊!o(∩∩)o...哈哈。

我试着改了下,但是好像循环有问题,出来的txt只有一个数值
do it =0, ntimes-1,1        ; TIME LOOP

    print("Working on time: " + times(it) )
    res@TimeLabel = times(it)   ; Set Valid time to use on plots

;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
; First get the variables we will need        
    if(isfilevar(a,"QICE"))
      qi = wrf_user_getvar(a,"QICE",it)
      qi = qi*1000.
      qi@units = "g/kg"   
    end if
    wmax = max(qi)
        print(wmax)
ascii_file = "data.txt"
asciiwrite(ascii_file, sprintf("%12.8f", wmax ))
end do
密码修改失败请联系微信:mofangbao

新浪微博达人勋

发表于 2014-4-23 16:18:58 | 显示全部楼层
黄小仙儿 发表于 2014-4-23 16:06
我试着改了下,但是好像循环有问题,出来的txt只有一个数值
do it =0, ntimes-1,1        ; TIME LOOP
...

wmax = max(qi)就一个值么,每次都写这个值到同一个文件。
要输出什么?是要把每个时次QICE的最大值输出到一个文件中吗?如果是,代码应该如下:

ascii_file = "data.txt"
str = new(ntimes, "string")

do it =0, ntimes-1,1        ; TIME LOOP

    print("Working on time: " + times(it) )
    res@TimeLabel = times(it)   ; Set Valid time to use on plots

;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
; First get the variables we will need        
    if(isfilevar(a,"QICE"))
      qi = wrf_user_getvar(a,"QICE",it)
      qi = qi*1000.
      qi@units = "g/kg"   
    end if
    wmax = max(qi)
    str(it) = sprintf("%12.8f", wmax)
end do

asciiwrite(ascii_file, str)
密码修改失败请联系微信:mofangbao

新浪微博达人勋

 楼主| 发表于 2014-4-23 18:33:32 | 显示全部楼层
longlivehj 发表于 2014-4-23 16:18
wmax = max(qi)就一个值么,每次都写这个值到同一个文件。
要输出什么?是要把每个时次QICE的最大值输出 ...

哇,谢谢大神~
密码修改失败请联系微信:mofangbao

新浪微博达人勋

发表于 2014-4-23 18:38:47 | 显示全部楼层

不客气。
想跟你说,其实可以用wrf_user_getvar一次性把数据全部取出,然后用dim_max_n直接生成最大值系列,避免循环。
密码修改失败请联系微信:mofangbao
您需要登录后才可以回帖 登录 | 立即注册 新浪微博登陆

本版积分规则

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

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

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