fortranでコンマ切りテキストファイル(CSVファイル)を
出力する方法をご存知の方、いらっしゃいませんでしょうか?
私が使用した処理系(intel fortran 8.0 for Windows)で
write(600,*)1.4,',',2.33,',',30.11
というコードを実行させると
fort.600 というファイル名のテキストファイルが生成されて
中身は
___1.400000_____,___2.330000_____,___30.11000____
となります。( _ は半角空白を意味します。)
私が欲しいのは余計な空白の入っていない
1.4,2.33,3.11
または
1.400000,2.330000,30.11000
という出力なのですが、どのような書式指定をすれば
これが可能なのでしょうか?
全くのfortran初心者です。よろしくご教示ください。
No.4ベストアンサー
- 回答日時:
汎用的な方法は、#2さんのように文字列として書き出して、adjustlやtrimを使って空白を取るのでしょうが、Intel Fortran8.0ならば以下のようなformatでできます。
write(600,10) 1.4,',',2.33,',',30.11
10 format(f0.6,a1,f0.6,a1,f0.6)
マイナス記号があっても問題ないです。書式幅が0の指定はIとFに使えます。なかなか便利ですよ。ちなみにConpaq Visual Fortranでも使えます。
本来の目的だった変数の場合に適用してみましたところ
x=1.4
y=2.33
z=30.11
write(600,10) x,',',y,',',z
10 format(f0.6,a1,f0.6,a1,f0.6)
以下のような出力を得ることが出来ました。
1.400000,2.330000,30.110001
どうもありがとうございました。
これで余計な処理が省けそうです。
No.3
- 回答日時:
エクセル上でコンマ区切りにできます。
エクセル上のファイルメニュー[データ]→[区切り位置]です。
データはA列を選んでください。
この回答への補足
ご回答ありがとうございました。
仰る通りなのですが、処理しなくてはならないファイル数が多いので、ご指摘の手順をマクロ化して自動化しないと実用には供さない思います。
(指定されたディレクトリに生成された多数のFortran出力ファイルを自動的に読み込んではCSVに書き換えてくれるようなマクロ?)
現状ではVisualBasicで上記マクロに相当するプログラムを作り、処理しております。
このため、Fortranには出力段階でCSVにできるような機能がもともと備わっているのかどうかを伺いたかった次第です。
あと、エクセルの列数は最大256列ではなかったでしょうか?
列数が256を超えてしまうことがありますので、シートに読み込んで作業を行うことは恐らく出来ないのではないでしょうか。
No.2
- 回答日時:
#1です。
桁数も有効数字も不明ならば、単純にwriteで変数を出力するだけではだめかと思います。変数の値を数値では無く、文字として文字列の変換をして出力する事が必要では無いでしょうか ?
ここら辺になる、私の知っている66では各社により
扱いがバラバラでした。77になって文字列が扱えるようになったと思います。私の範囲を超えてしまいました。お役に立てず申し訳ございません。
No.1
- 回答日時:
大昔のfortran(66)しか知らないのですが、
write(600,*)1.4,',',2.33,',',30.11
のところを
write(600,1)1.4,',',2.33,',',30.11
1 format(f4.1,',',f5.2,',',f6.2)
とかしたら駄目なのかしら ?
ただ符号が最初に入るから、やっぱり1つスペースが
入っちゃうかな ??
この回答への補足
ご回答ありがとうございます。
即値に対してはおっしゃる通りの書式指定でコンマ切りテキストになると思います。
が、実際のコードでは
1.4
2.33
30.11
の部分は変数になります。
またその変数に代入されている実際の計算結果は
0.1
だったり
0.0001
だったり、あるいは
0.123456
だったりします。
計算結果の有効数字が計算する前にあらかじめわかっていないと書式指定ではコンマ切りテキストは作れないのでしょうか?
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
海外旅行から帰ってきたら、まず何を食べる?
帰国して1番食べたくなるもの、食べたくなるだろうなと思うもの、皆さんはありますか?
-
フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
あなたが普段思っている「これまだ誰も言ってなかったけど共感されるだろうな」というあるあるを教えてください
-
映画のエンドロール観る派?観ない派?
映画が終わった後、すぐに席を立って帰る方もちらほら見かけます。皆さんはエンドロールの最後まで観ていきますか?
-
海外旅行から帰ってきたら、まず何を食べる?
帰国して1番食べたくなるもの、食べたくなるだろうなと思うもの、皆さんはありますか?
-
天使と悪魔選手権
悪魔がこんなささやきをしていたら、天使のあなたはなんと言って止めますか?
-
fortranでプログラムを実行するとEnd of fileと表示されてしまいます
その他(プログラミング・Web制作)
-
fortranでデータの抜き出しをしたい
その他(プログラミング・Web制作)
-
intel fortranのエラーで困ってます.
その他(プログラミング・Web制作)
-
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・人生のプチ美学を教えてください!!
- ・10秒目をつむったら…
- ・あなたの習慣について教えてください!!
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・【大喜利】【投稿~9/18】 おとぎ話『桃太郎』の知られざるエピソード
- ・街中で見かけて「グッときた人」の思い出
- ・「一気に最後まで読んだ」本、教えて下さい!
- ・幼稚園時代「何組」でしたか?
- ・激凹みから立ち直る方法
- ・1つだけ過去を変えられるとしたら?
- ・【あるあるbot連動企画】あるあるbotに投稿したけど採用されなかったあるある募集
- ・【あるあるbot連動企画】フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
- ・映画のエンドロール観る派?観ない派?
- ・海外旅行から帰ってきたら、まず何を食べる?
- ・誕生日にもらった意外なもの
- ・天使と悪魔選手権
- ・ちょっと先の未来クイズ第2問
- ・【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
- ・推しミネラルウォーターはありますか?
- ・都道府県穴埋めゲーム
- ・この人頭いいなと思ったエピソード
- ・準・究極の選択
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
Excel.VBA テキストファイルを...
-
VBAでPowerPointからExcelにデ...
-
バッチでiniファイルの編集
-
A列をテキストファイル名に、B...
-
テキストファイルを直接置換す...
-
複数行の文字列を変数として使...
-
iniファイルとの比較(iniファイ...
-
unicode文字列(日本語)のファイ...
-
特定フォルダ内のテキストファ...
-
VBAで新しい日付順にファイルを...
-
ExcelVBAで以下のマクロを作成...
-
BCPユーティリティの使用法_...
-
VB6側からテキストファイルをク...
-
access vbaでCSVファイルを文...
-
fortranでのcsvファイルを出力...
-
H8マイコンにおける演算結果の...
-
ある文字列を含む行の抽出
-
excelにテキストファイルの指定...
-
コマンドプロンプトの「%1」と...
-
コマンドプロンプトのエラーに...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
特定フォルダ内のテキストファ...
-
複数行の文字列を変数として使...
-
テキストファイルの行頭に文字...
-
VB6側からテキストファイルをク...
-
BCPユーティリティの使用法_...
-
fortranでのcsvファイルを出力...
-
テキストファイルを直接置換す...
-
VBAで新しい日付順にファイルを...
-
access vbaでCSVファイルを文...
-
バッチでiniファイルの編集
-
ある文字列を含む行の抽出
-
RandomとBinaryモードの違い
-
VBAでPowerPointからExcelにデ...
-
Excel.VBA テキストファイルを...
-
A列をテキストファイル名に、B...
-
VBAで任意のフォルダ内のファイ...
-
時間短縮のために、テキストフ...
-
unicode文字列(日本語)のファイ...
-
複数のCSVの指定行だけを残し、...
-
ExcelVBAで以下のマクロを作成...
おすすめ情報