
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で質問しましょう!
似たような質問が見つかりました
- その他(プログラミング・Web制作) Fortranでの出力ファイル 2 2023/03/21 21:25
- Visual Basic(VBA) エクセルのマクロについて教えてください。 1 2023/08/08 11:02
- Excel(エクセル) エクセルのVBAについて とあるサイトのコードを参考に、CSVの文字化けを直すVBAを作成しているの 7 2022/11/04 14:15
- Visual Basic(VBA) エクセルのマクロについて教えてください。 2 2023/07/15 15:12
- Visual Basic(VBA) VBAで特定の場所にあるCSVファイル(複数)から特定場所を抜き出してExcelに転記したいです。 11 2023/05/23 16:29
- Visual Basic(VBA) エクセルのマクロについて教えてください。 2 2023/07/15 15:48
- その他(プログラミング・Web制作) データ解析ソフトRでのファイル入力read.csvがエラーになります 7 2022/03/27 22:11
- Excel(エクセル) エクセルでcsvファイルを開いてVBAを使いたい 7 2022/04/28 11:12
- Visual Basic(VBA) VBAのユーザーフォームのテキストボックスに入力制限をしたい 6 2022/11/15 08:28
- Java java 次の機能を有するメソッドを自クラスに作成し、実装したいです。 機能 名前判定機能 →名前が 3 2022/06/16 16:08
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
C言語でのファイルの読み込み方
-
VBAで新しい日付順にファイルを...
-
他のExcelファイルのVBAコード...
-
VBAでPowerPointからExcelにデ...
-
テキストファイルの重複
-
[ASP+File操作]長いファイル名...
-
ページレイアウトをHTMLファイ...
-
マクロでの処理結果をログファ...
-
VBScriptについて教えてください!
-
UTL_FILE_DIRについて
-
大量のフォルダからひとつのフ...
-
コマンドプロンプトのエラーに...
-
'msimg32.lib'は通常どこにある...
-
これってパソコンの最適化が完...
-
binファイルを解凍したいの...
-
win10の「フォト」で、「次へ」...
-
住所録の新旧統合の仕方?
-
iTunes データ移動に失敗しました
-
ファイルオープンの速度を速く...
-
コマンドプロンプトの「%1」と...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
ある文字列を含む行の抽出
-
特定フォルダ内のテキストファ...
-
VBAでPowerPointからExcelにデ...
-
VB6側からテキストファイルをク...
-
BCPユーティリティの使用法_...
-
Excel.VBA テキストファイルを...
-
unicode文字列(日本語)のファイ...
-
テキストファイルの行頭に文字...
-
access vbaでCSVファイルを文...
-
複数行の文字列を変数として使...
-
バッチでiniファイルの編集
-
excelにテキストファイルの指定...
-
RandomとBinaryモードの違い
-
時間短縮のために、テキストフ...
-
テキストファイルを直接置換す...
-
VB.NETでテキストファイルからH...
-
C#でのファイル編集と上書き保...
-
ExcelVBAで以下のマクロを作成...
-
VBSを用いてIPアドレスを取得し...
-
VBAで新しい日付順にファイルを...
おすすめ情報