24小时热门版块排行榜    

查看: 1763  |  回复: 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的回帖

马墨迹

金虫 (小有名气)

马克

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

qchem

铁杆木虫 (著名写手)



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

[ 发自小木虫客户端 ]
4楼2015-02-01 23:50:26
已阅   回复此楼   关注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的回帖
普通表情 高级回复 (可上传附件)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[公派出国] 售SCI一区文章,我:8 O5 51O 54,科目齐全 +3 5lbyq5wrhb 2026-02-07 4/200 2026-02-08 08:47 by vs90ilomwc
[考博] 售SCI一区文章,我:8 O5 51O 54,科目齐全 +3 5lbyq5wrhb 2026-02-07 4/200 2026-02-08 08:46 by vs90ilomwc
[硕博家园] 售SCI一区文章,我:8 O5 51O 54,科目齐全 +3 3rkserf6qr 2026-02-07 4/200 2026-02-08 08:27 by vs90ilomwc
[硕博家园] 售SCI一区文章,我:8 O5 51O 54,科目齐全 +5 2h7du0nuhk 2026-02-07 6/300 2026-02-08 08:26 by vs90ilomwc
[考博] 售SCI一区文章,我:8 O5 51O 54,科目齐全 +5 2h7du0nuhk 2026-02-07 6/300 2026-02-08 08:12 by vs90ilomwc
[硕博家园] 售SCI一区文章,我:8 O5 51O 54,科目齐全 +4 2h7du0nuhk 2026-02-07 6/300 2026-02-08 08:07 by vs90ilomwc
[考博] 售SCI一区文章,我:8 O5 51O 54,科目齐全 +4 2h7du0nuhk 2026-02-07 7/350 2026-02-08 08:06 by vs90ilomwc
[教师之家] 售SCI一区文章,我:8 O5 51O 54,科目齐全 +4 2h7du0nuhk 2026-02-07 7/350 2026-02-08 07:52 by vs90ilomwc
[公派出国] 售SCI一区文章,我:8 O5 51O 54,科目齐全 +4 2h7du0nuhk 2026-02-07 8/400 2026-02-08 07:32 by vs90ilomwc
[考博] 售SCI一区文章,我:8 O5 51O 54,科目齐全 +4 2h7du0nuhk 2026-02-07 8/400 2026-02-08 07:27 by vs90ilomwc
[教师之家] 售SCI一区文章,我:8 O5 51O 54,科目齐全 +4 2h7du0nuhk 2026-02-07 8/400 2026-02-08 07:26 by vs90ilomwc
[硕博家园] 售SCI一区文章,我:8 O5 51O 54,科目齐全 +4 2h7du0nuhk 2026-02-07 8/400 2026-02-08 07:07 by vs90ilomwc
[硕博家园] 博士延得我,科研能力直往上蹿 +8 偏振片 2026-02-02 8/400 2026-02-08 06:52 by liyeqik
[教师之家] 有院领导为了换新车,用横向课题经费买了俩车 +7 瞬息宇宙 2026-02-04 7/350 2026-02-07 21:47 by tfang
[有机交流] 酰胺脱乙酰基 10+5 chibby 2026-02-03 12/600 2026-02-07 19:29 by 江东闲人
[基金申请] 同年申请2项不同项目,第1个项目里不写第2个项目的信息,可以吗 +4 hitsdu 2026-02-06 4/200 2026-02-07 13:07 by jurkat.1640
[基金申请] 有时候真觉得大城市人没有县城人甚至个体户幸福 +9 苏东坡二世 2026-02-04 10/500 2026-02-07 12:37 by 小毛球
[考博] 天津大学招2026.09的博士生,欢迎大家推荐交流(博导是本人) +4 a793625982 2026-02-05 5/250 2026-02-07 10:57 by a793625982
[公派出国] CSC & MSCA 博洛尼亚大学能源材料课题组博士/博士后招生|MSCA经费充足、排名优 +4 雨念 2026-02-01 6/300 2026-02-06 23:32 by MelissaPon
[基金申请] 面上项目申报 +3 Tide man 2026-02-01 3/150 2026-02-05 22:56 by god_tian
信息提示
请填处理意见