
No.2ベストアンサー
- 回答日時:
speedとpowerはdouble型の行列ですよね?
fwrite関数はバイナリ保存関数ですので、CSV形式(=テキスト形式)での保存はできません。
dlmwrite関数では小数点以下12桁までを指定して保存していますので、fprintf関数を使用すれば良いのではないかと思います。
なお、fprintf関数を使用する場合は、区切文字(,)や改行は自動で追加されませんので、以下のように記述する必要があります。
fprintf(fid, '%.12f,', speed);
fprintf(fid, '\n');
fprintf(fid, '%.12f,', power);
fprintf(fid, '\n');
ただ、この方法では各行の末尾にもカンマが出力されますので、それを抑止したい場合は、speedとpowerの各要素をループの中で保存してください。
■ fprintf関数
http://infoshako.sk.tsukuba.ac.jp/InfoRes/jdoc/M …
また、プログラムではfor文の中でfopenとfcloseを繰り返していますが、余り良いことではありません。見たところファイル名は一定のようですので、fopenとfcloseはfor文の外でするべきだと思います。そうすれば処理速度も向上しますし、別に追記でfopenする必要もありません。
fid = fopen('file1.csv', 'w');
for
fprintf(fid, ....);
end
fclose(fid);
最後に、この場合はファイルの出力方法を変更する以外に、speedとpowerをループ回数分保存するように変更する方法もあるのではないかと思います。
No.1
- 回答日時:
fopen関数のpermissionの指定を「a」か「a+」にすれば追記が可能です。
■ fopen関数
http://infoshako.sk.tsukuba.ac.jp/InfoRes/jdoc/M …
sgwjnさん,迅速に回答していただきましてありがとうございます!
教えて頂いた通りやってみました!
************************************************************
for...
途中省略
fid = fopen('file1.csv','a+' )
fwrite(fid,speed,'double')
fwrite(fid,power,'double')
fclose(fid)
next
************************************************************
と,プログラムしたのですが,エクセルで開くと変な文字になってしまいました.
ちなみにspeedとpowerは計算させた1×101の行列です.
以前は以下のように書き込みをしていたのですが・・・
************************************************************
dlmwrite(file1.csv',[speed;power]', 'precision', '%.12f',...
'delimiter',',','roffset',0,'coffset',0)
************************************************************
これだと,ちゃんとエクセルで開けて問題なかったのですが,
今回はforループで繰り返し計算させながら
書き込みさせなくてはいけないので,これをループの中に入れたら
最後のループしか書き込みされませんでした.
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Access(アクセス) CSVファイルの「0落ち」にVBA 6 2023/02/02 15:27
- Excel(エクセル) PowerQueryに詳しい方教えてください(Office365) 1 2022/07/24 21:11
- Excel(エクセル) エクセルのVBAについて とあるサイトのコードを参考に、CSVの文字化けを直すVBAを作成しているの 7 2022/11/04 14:15
- その他(プログラミング・Web制作) Fortranでの出力ファイル 2 2023/03/21 21:25
- Visual Basic(VBA) VBA 毎日取得するデータを順番に反映していく方法 6 2023/08/26 16:22
- Excel(エクセル) エクセルでcsvファイルを開いてVBAを使いたい 7 2022/04/28 11:12
- システム CSVファイルのマッピング処理の省力化 1 2022/11/24 00:01
- Excel(エクセル) csvに別のExcelの文章を差し込む 2 2023/04/01 16:06
- Visual Basic(VBA) VBAで出力したCSVファイルの先頭にカンマを挿入したい 5 2022/10/14 12:20
- Excel(エクセル) csvファイルをExcel形式で読み込むには 2 2023/07/03 13:09
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
データバインディングがうまく...
-
コマンド(例えばls)の出力結果...
-
JAVAアプレットで画像保存
-
【ExcelVBA】UTF-8(BOM無)でC...
-
VC++でUTF-8のファイルを出力し...
-
Acccess レポートをグループ別...
-
名前をつけて保存する
-
COBOLのファイル出力
-
アクセス>マクロ>テキスト変換
-
Wordマクロで指定したフォルダ...
-
C#でエクセルみたいな重複行削除
-
シェルコマンドの 2>&1 とはど...
-
c言語の質問です。 ランダムに4...
-
フォルダにあるPDF情報の抽出(VBA)
-
flash動画をDVDに焼いたが再生...
-
テキストファイルに改行コード...
-
ファイル形式またはファイル拡...
-
Base64でエンコードした後の文...
-
SendKeys "^V", True(貼り付け...
-
fortranのプログラムについて ...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
コマンド(例えばls)の出力結果...
-
【ExcelVBA】UTF-8(BOM無)でC...
-
ファイル出力の場所を指定
-
VC++でUTF-8のファイルを出力し...
-
ファイルの文字コードをUTF-8に...
-
シェルコマンドの 2>&1 とはど...
-
Acccess レポートをグループ別...
-
BitBltについて。
-
Wordマクロで指定したフォルダ...
-
CSV形式に変換
-
ファイル形式またはファイル拡...
-
テキストファイルに改行コード...
-
C++ fprintf_sの使い方がわからん
-
外国語とCSVについて
-
1行ずつではなくまとめてファイ...
-
重複チェックプログラム
-
pcap形式データをテキストへ抽出
-
AviUtlでAVI出力が途中までしか...
-
標準出力とファイルに効率的に...
-
C++/CLIにて、System.String^型...
おすすめ情報