Fortran 板


LINE

初學fortran 只會用簡單的計算跟一些迴圈 由於現在用軟體算出來的output 夾雜英文和數字 想請問 有沒有辦法用找特定兩個關鍵字的方式 去讀在這兩個關鍵字中的數據 再把它寫出到另一個資料夾 做了一下功課 好像是需要使用到 index bacspace 跟 do 跳行 orientation: --------------------------------------------------------------------- Center Atomic Atomic Coordinates (Angstroms) Number Number Type X Y Z --------------------------------------------------------------------- 1 6 0 2.422098 -0.365891 0.476931 2 8 0 2.669932 -1.186283 1.333641 3 8 0 3.283776 0.059986 -0.453423 4 6 0 4.606155 -0.505397 -0.372798 . . . . . . --------------------------------------------------------------------- xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx . . . . . completed 大致上的數據格式是這樣,從orientation 到completer 有大概一千行 一個檔案裏面有大約40組這樣的內容 我想的流程大概是 先尋找到completed 然後使用backspace往上搜尋找到orientation 然後使用跳行讀取跳過前面 再來讀取 X Y Z 下的數據 然後跳出到找到completed的行數接著尋找completed 但是礙於能力有限具體的方式不太了解 所以想麻煩大家指點一下 謝謝 暫時把CODE整理成這樣 但是還是沒有辦法達成目的 PROGRAM EE IMPLICIT NONE CHARACTER(LEN=80) :: TXT INTEGER :: FIOS,CN,AN,AT REAL*8 X1,Y1,Z1 OPEN(UNIT=11,FILE="Text3.txt") OPEN(UNIT=12,FILE="XYZ.TXT") DO WHILE(.TRUE.) READ(11,"(A80)",IOSTAT=FIOS) TXT IF(TXT=="Optimization completed.") THEN Backspace(11) Backspace(11) END IF DO WHILE(.TRUE.) READ(11,"(A80)",IOSTAT=FIOS) TXT IF (LEN_TRIM(TXT)/="Standard orientation:")THEN Backspace(11) Backspace(11) ELSE IF(LEN_TRIM(TXT)=="Standard orientation:") THEN REWIND(12) READ(11,*,IOSTAT=FIOS) READ(11,*,IOSTAT=FIOS) READ(11,*,IOSTAT=FIOS) READ(11,*,IOSTAT=FIOS) DO WHILE(.TRUE.) READ(11,"(A80)",IOSTAT=FIOS) TXT IF(TXT=="--------------------------------") EXIT READ(TXT,*,IOSTAT=FIOS) CN,AN,AT,X1,Y1,Z1 PRINT *, X1,Y1,Z1 WRITE(12,*) X1,Y1,Z1 END DO END IF END DO END DO STOP END 還請有看到的大大指點迷津 --



※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 140.117.58.73
※ 文章網址: http://webptt.com/m.aspx?n=bbs/Fortran/M.1418059835.A.5A9.html
1F:推 kkarthur: 讀取一次即可,並不需要用到backspace 12/09 10:24
2F:→ kkarthur: 流程大概如下 12/09 10:24
3F:→ kkarthur: 1. 一行行把檔案內容字串存成變數 12/09 10:25
4F:→ kkarthur: 2. IF(內容=="orientation") 就把下面幾行座標存起來 12/09 10:26
5F:→ kkarthur: 3.IF(內容=="completed") 就印出成功並顯示座標 12/09 10:27
6F:推 kkarthur: 流程2即使前面會因為同樣的關鍵字而變數重複被覆蓋 12/09 10:30
7F:→ kkarthur: 但能保證看到completed之前所讀取的資料一直是較新的 12/09 10:31
※ 編輯: kitsune128 (140.117.58.73), 12/10/2014 02:43:49
8F:→ weiny1992: TRIM(TXT)才對喔 LEN_TRIM是整數 12/10 18:06







like.gif 您可能會有興趣的文章
icon.png[問題/行為] 貓晚上進房間會不會有憋尿問題
icon.pngRe: [閒聊] 選了錯誤的女孩成為魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一張
icon.png[心得] EMS高領長版毛衣.墨小樓MC1002
icon.png[分享] 丹龍隔熱紙GE55+33+22
icon.png[問題] 清洗洗衣機
icon.png[尋物] 窗台下的空間
icon.png[閒聊] 双極の女神1 木魔爵
icon.png[售車] 新竹 1997 march 1297cc 白色 四門
icon.png[討論] 能從照片感受到攝影者心情嗎
icon.png[狂賀] 賀賀賀賀 賀!島村卯月!總選舉NO.1
icon.png[難過] 羨慕白皮膚的女生
icon.png閱讀文章
icon.png[黑特]
icon.png[問題] SBK S1安裝於安全帽位置
icon.png[分享] 舊woo100絕版開箱!!
icon.pngRe: [無言] 關於小包衛生紙
icon.png[開箱] E5-2683V3 RX480Strix 快睿C1 簡單測試
icon.png[心得] 蒼の海賊龍 地獄 執行者16PT
icon.png[售車] 1999年Virage iO 1.8EXi
icon.png[心得] 挑戰33 LV10 獅子座pt solo
icon.png[閒聊] 手把手教你不被桶之新手主購教學
icon.png[分享] Civic Type R 量產版官方照無預警流出
icon.png[售車] Golf 4 2.0 銀色 自排
icon.png[出售] Graco提籃汽座(有底座)2000元誠可議
icon.png[問題] 請問補牙材質掉了還能再補嗎?(台中半年內
icon.png[問題] 44th 單曲 生寫竟然都給重複的啊啊!
icon.png[心得] 華南紅卡/icash 核卡
icon.png[問題] 拔牙矯正這樣正常嗎
icon.png[贈送] 老莫高業 初業 102年版
icon.png[情報] 三大行動支付 本季掀戰火
icon.png[寶寶] 博客來Amos水蠟筆5/1特價五折
icon.pngRe: [心得] 新鮮人一些面試分享
icon.png[心得] 蒼の海賊龍 地獄 麒麟25PT
icon.pngRe: [閒聊] (君の名は。雷慎入) 君名二創漫畫翻譯
icon.pngRe: [閒聊] OGN中場影片:失蹤人口局 (英文字幕)
icon.png[問題] 台灣大哥大4G訊號差
icon.png[出售] [全國]全新千尋侘草LED燈, 水草

請輸入看板名稱,例如:BabyMother站內搜尋

TOP