24小时热门版块排行榜    

查看: 1810  |  回复: 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 的主题更新
普通表情 高级回复 (可上传附件)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 311求调剂 +6 冬十三 2026-03-15 6/300 2026-03-16 08:00 by wang_dand
[教师之家] 焦虑 +6 水冰月月野兔 2026-03-13 8/400 2026-03-16 06:39 by lfq_198989
[文学芳草园] 伙伴们,祝我生日快乐吧 +15 myrtle 2026-03-10 24/1200 2026-03-15 21:16 by 苏州_逗号
[考研] 求老师收留调剂 +4 jiang姜66 2026-03-14 5/250 2026-03-15 20:11 by Winj1e
[考研] 东南大学364求调剂 +3 JasonYuiui 2026-03-15 3/150 2026-03-15 18:57 by 无际的草原
[考研] 085600材料与化工 求调剂 +11 enenenhui 2026-03-13 12/600 2026-03-14 21:48 by laoshidan
[考研] 309求调剂 +4 花与叶@ 2026-03-10 4/200 2026-03-14 21:26 by a不易
[考研] 材料080500调剂求收留 +3 一颗meteor 2026-03-13 3/150 2026-03-14 10:54 by peike
[考研] 308求调剂 +4 是Lupa啊 2026-03-09 4/200 2026-03-14 02:06 by tranquil_ya
[考研] 材料与化工304求B区调剂 +5 邱gl 2026-03-11 6/300 2026-03-13 22:37 by JourneyLucky
[考研] 泣血叩求调剂恩,愿以丹心报师恩 +6 Iuruoh 2026-03-11 6/300 2026-03-13 22:06 by JourneyLucky
[考研] 290求调剂 +9 ADT 2026-03-11 9/450 2026-03-13 21:55 by JourneyLucky
[考研] 310求调剂 +3 【上上签】 2026-03-11 3/150 2026-03-13 16:16 by JourneyLucky
[考研] 08食品或轻工求调剂,本科发表3篇sci一区top论文,一志愿南师大食品科学与工程 +3 我是一个兵, 2026-03-10 3/150 2026-03-13 10:21 by Yuyi.
[考研] 333求调剂 +3 152697 2026-03-12 4/200 2026-03-13 07:08 by Iveryant
[考研] 085600 材料与化工 295 求调剂 +10 dream…… 2026-03-10 12/600 2026-03-12 13:46 by dream……
[考博] 读博申请 +5 感dd 2026-03-10 7/350 2026-03-11 17:02 by QGZDSYS
[考研] 化工0817调剂 +8 灿若星晨 2026-03-10 8/400 2026-03-10 22:44 by 星空星月
[考研] 一志愿:武汉理工,材料工程,英二数二 总分314 +3 2202020125 2026-03-10 4/200 2026-03-10 13:54 by xiongyaxuan
[考研] 家人们 调剂不迷路 看这里 +8 likeihood 2026-03-09 13/650 2026-03-10 08:09 by likeihood
信息提示
请填处理意见