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.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
だったりします。
計算結果の有効数字が計算する前にあらかじめわかっていないと書式指定ではコンマ切りテキストは作れないのでしょうか?
No.2
- 回答日時:
#1です。
桁数も有効数字も不明ならば、単純にwriteで変数を出力するだけではだめかと思います。変数の値を数値では無く、文字として文字列の変換をして出力する事が必要では無いでしょうか ?
ここら辺になる、私の知っている66では各社により
扱いがバラバラでした。77になって文字列が扱えるようになったと思います。私の範囲を超えてしまいました。お役に立てず申し訳ございません。
No.3
- 回答日時:
エクセル上でコンマ区切りにできます。
エクセル上のファイルメニュー[データ]→[区切り位置]です。
データはA列を選んでください。
この回答への補足
ご回答ありがとうございました。
仰る通りなのですが、処理しなくてはならないファイル数が多いので、ご指摘の手順をマクロ化して自動化しないと実用には供さない思います。
(指定されたディレクトリに生成された多数のFortran出力ファイルを自動的に読み込んではCSVに書き換えてくれるようなマクロ?)
現状ではVisualBasicで上記マクロに相当するプログラムを作り、処理しております。
このため、Fortranには出力段階でCSVにできるような機能がもともと備わっているのかどうかを伺いたかった次第です。
あと、エクセルの列数は最大256列ではなかったでしょうか?
列数が256を超えてしまうことがありますので、シートに読み込んで作業を行うことは恐らく出来ないのではないでしょうか。
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
どうもありがとうございました。
これで余計な処理が省けそうです。
お探しの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も見ています
-
プロが教えるわが家の防犯対策術!
ホームセキュリティのプロが、家庭の防犯対策を真剣に考える 2組のご夫婦へ実際の防犯対策術をご紹介!どうすれば家と家族を守れるのかを教えます!
-
fortranでデータの抜き出しをしたい
その他(プログラミング・Web制作)
-
fortranのtxtファイル出力書式について
その他(プログラミング・Web制作)
-
fortranでプログラムを実行するとEnd of fileと表示されてしまいます
その他(プログラミング・Web制作)
-
-
4
fortranでのcsvファイルの読み込み
その他(プログラミング・Web制作)
-
5
FORTRANの実行エラーについて
その他(プログラミング・Web制作)
-
6
Fortranで1行飛ばして読み込む方法
その他(プログラミング・Web制作)
-
7
フォートランで出力をタブ区切りテキストの形式でしたいのですが
その他(プログラミング・Web制作)
-
8
フォートランのエラーについて(forrtl)
その他(プログラミング・Web制作)
-
9
【fortran77】データ行数のカウント
その他(プログラミング・Web制作)
-
10
FORTRAN 複素数 (実部を取り出す方法)
その他(プログラミング・Web制作)
-
11
fortran if文
その他(プログラミング・Web制作)
-
12
Fortran:列数の分からないデータの読み込み
その他(プログラミング・Web制作)
-
13
fortranでNAのあるデータを読み込みたいです
その他(プログラミング・Web制作)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
VBAでPowerPointからExcelにデ...
-
access vbaでCSVファイルを文...
-
unicode文字列(日本語)のファイ...
-
VBAで新しい日付順にファイルを...
-
fortranでのcsvファイルを出力...
-
ある文字列を含む行の抽出
-
複数行の文字列を変数として使...
-
特定フォルダ内のテキストファ...
-
Excel.VBA テキストファイルを...
-
ソースコードの差分がある行番...
-
BCPユーティリティの使用法_...
-
テキストファイルを直接置換す...
-
フォルダ比較の結果をテキスト...
-
iniファイルとの比較(iniファイ...
-
コマンドプロンプトの「%1」と...
-
コマンドプロンプトのエラーに...
-
画像・動画データを日付毎のフ...
-
バッチでテキストファイルから...
-
大量のフォルダからひとつのフ...
-
Thunderbirdで社内共有フォルダ...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
VBAでPowerPointからExcelにデ...
-
複数行の文字列を変数として使...
-
特定フォルダ内のテキストファ...
-
VBAで新しい日付順にファイルを...
-
VB6側からテキストファイルをク...
-
テキストファイルを直接置換す...
-
RandomとBinaryモードの違い
-
Excel.VBA テキストファイルを...
-
バッチでiniファイルの編集
-
fortranでのcsvファイルを出力...
-
ある文字列を含む行の抽出
-
テキストファイルの行頭に文字...
-
access vbaでCSVファイルを文...
-
C#でのファイル編集と上書き保...
-
BCPユーティリティの使用法_...
-
unicode文字列(日本語)のファイ...
-
c言語の問題です
-
VBSを用いてIPアドレスを取得し...
-
VBAで任意のフォルダ内のファイ...
-
excelにテキストファイルの指定...
おすすめ情報