24小时热门版块排行榜    

查看: 1695  |  回复: 8

beefly

专家顾问 (职业作家)

地沟油冶炼专家

[交流] 在Fortran程序中,自定义打印数据列数的三种方法 已有7人参与

有时候为了便于数据显示和后期的数据处理,我们希望能控制Fortran程序打印的数据列数,但是write语句不允许在格式控制符中加入变量。其实通过一些技巧,这是可以实现的。

示例代码如下:
CODE:
    IMPLICIT DOUBLE PRECISION (A-H,O-Z)
    dimension a(20),b(20),c(20)
    character*100 frmt

    a=1.d0
    b=2.d0
    c=3.d0

    write(*,*)"Please specify the number of columns (default: 5):"
    read(*,*) ncol
    if(ncol .lt. 1) ncol=5

    write(*,"(/,'a=')")
    do i=1,20
      write(*,"(f20.12)",advance='no')a(i)
      if(mod(i,ncol) .eq. 0) write(*,*)
    end do
    write(*,*)

    frmt='(    f11.3)'
    write(frmt(2:5),"(i4)")ncol
    write(*,"(/,'b=')")
    write(*,trim(frmt))b
    write(*,*)

    write(*,*)"Please specify the format (for example, 5f12.6):"
    read(*,*)frmt
    frmt="(" // trim(frmt) // ")"
    write(*,"(/,'c=')")
    write(*,trim(frmt))c

    end

首先,由用户定义输出的列数:
CODE:
    Please specify the number of columns (default: 5):
     3  用户输入

例1,打印数组a。这里利用了Fortran90引入的一个wreite选项advance='no',表示打印之后不换行。注意此选项对Fortran 77编译器(例如pgf77,g77)无效。每次只打印一个数组的元素,当数据编号能被列数整除时,执行一个空的write命令,起到换行作用。输出为:
CODE:
    a=
          1.000000000000      1.000000000000      1.000000000000
          1.000000000000      1.000000000000      1.000000000000
          1.000000000000      1.000000000000      1.000000000000
          1.000000000000      1.000000000000      1.000000000000
          1.000000000000      1.000000000000      1.000000000000
          1.000000000000      1.000000000000      1.000000000000
          1.000000000000      1.000000000000

例2,打印数组b。这里利用字符串frmt存储输出格式,并利用write语句把自定义的整型列数作为字符打印到frmt,把frmt预留的第2到第5个字符位置改为用户定义的列数。在上面的例子中,frmt改后成为(   3f11.3)。我们一般只输出几列到几十列,因此预留4个字符位置一般足够了。输出为:
CODE:
    b=
          2.000      2.000      2.000
          2.000      2.000      2.000
          2.000      2.000      2.000
          2.000      2.000      2.000
          2.000      2.000      2.000
          2.000      2.000      2.000
          2.000      2.000

例3,打印数组c。这个例子可看作是例2的扩展,输出更灵活一些。不仅是列数,每个元素的输出格式也都由用户按照Fortran的格式定义。例如:
CODE:
    Please specify the format (for example, 5f12.6):
       4d16.6    用户输入

然后根据Fortran格式,还要把前后的括号加上。输出如下:
CODE:
    c=
        0.300000D+01    0.300000D+01    0.300000D+01    0.300000D+01
        0.300000D+01    0.300000D+01    0.300000D+01    0.300000D+01
        0.300000D+01    0.300000D+01    0.300000D+01    0.300000D+01
        0.300000D+01    0.300000D+01    0.300000D+01    0.300000D+01
        0.300000D+01    0.300000D+01    0.300000D+01    0.300000D+01

用户自定义的格式未必总是符合语法的。如果作为正式的程序,最好给write加上一个出错判断:若给定格式的输出无法执行,则按照默认格式输出。
回复此楼

» 本帖已获得的红花(最新10朵)

» 猜你喜欢

» 本主题相关价值贴推荐,对您同样有帮助:

beefly《西太平洋大学现代英汉词典》[bi:fli]牛肉一般地
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
送红花一朵
2楼2015-02-01 07:23:05
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

xk6891

至尊木虫 (著名写手)

送红花一朵
有想法
人生自古多险阻,勤者自得天酬助。试问否泰何所依,枯藤老枝待新抽。临渊踌躇终迈步,振翅鹏起云霄冲。似是前程甚堪忧,他日振臂揽苍穹。
3楼2015-02-01 22:31:00
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

qchem

铁杆木虫 (著名写手)



小木虫: 金币+0.5, 给个红包,谢谢回帖
还可以考虑用内部文件来实现

[ 发自小木虫客户端 ]
4楼2015-02-01 23:50:26
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

马墨迹

金虫 (小有名气)

马克

[ 发自小木虫客户端 ]
墨迹不磨叽
5楼2015-02-02 00:23:04
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

yebin2006

木虫 (小有名气)

好帖,顶!

[ 发自小木虫客户端 ]
comeon~!
6楼2015-02-02 00:28:53
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

pippi6

铁杆木虫 (著名写手)

工程和科学数值计算咨询


小木虫: 金币+0.5, 给个红包,谢谢回帖
“但是write语句不允许在格式控制符中加入变量”  lz 的这个论断是不正确的。 比如 n 是一个正整数,我希望打印 n 用合适的整数位,就可以写
  write(6,"(a,I<int(log10(n+0d0))+1>" ' n=',n
一般说来  变量可以放在尖括弧中,像<n>,作为控制符
所以,有些技巧也是不需要的
7楼2015-02-02 22:40:40
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

beefly

专家顾问 (职业作家)

地沟油冶炼专家

引用回帖:
7楼: Originally posted by pippi6 at 2015-02-02 22:40:40
“但是write语句不允许在格式控制符中加入变量”  lz 的这个论断是不正确的。 比如 n 是一个正整数,我希望打印 n 用合适的整数位,就可以写
  write(6,"(a,I<int(log10(n+0d0))+1>" ' n=',n
...

谢谢!我以前试过括号,引号,等等,都不行。10年前在smth的计算版中问过,所有人都告诉我是不可能的,让我断了此念...
beefly《西太平洋大学现代英汉词典》[bi:fli]牛肉一般地
8楼2015-02-02 22:58:17
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

smutao

禁虫 (著名写手)


小木虫: 金币+0.5, 给个红包,谢谢回帖
本帖内容被屏蔽

9楼2015-06-30 05:19:58
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 beefly 的主题更新
普通表情 高级回复 (可上传附件)
信息提示
请填处理意见