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で質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・人生のプチ美学を教えてください!!
- ・10秒目をつむったら…
- ・あなたの習慣について教えてください!!
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・【大喜利】【投稿~9/18】 おとぎ話『桃太郎』の知られざるエピソード
- ・街中で見かけて「グッときた人」の思い出
- ・「一気に最後まで読んだ」本、教えて下さい!
- ・幼稚園時代「何組」でしたか?
- ・激凹みから立ち直る方法
- ・1つだけ過去を変えられるとしたら?
- ・【あるあるbot連動企画】あるあるbotに投稿したけど採用されなかったあるある募集
- ・【あるあるbot連動企画】フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
- ・映画のエンドロール観る派?観ない派?
- ・海外旅行から帰ってきたら、まず何を食べる?
- ・誕生日にもらった意外なもの
- ・天使と悪魔選手権
- ・ちょっと先の未来クイズ第2問
- ・【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
- ・推しミネラルウォーターはありますか?
- ・都道府県穴埋めゲーム
- ・この人頭いいなと思ったエピソード
- ・準・究極の選択
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
コマンド(例えばls)の出力結果...
-
外国語とCSVについて
-
ファイルの文字コードをUTF-8に...
-
VBSでEXCEL⇒CSV変換で日付の書...
-
printfだと出力されるのにfprin...
-
VC++でUTF-8のファイルを出力し...
-
CreateProcess関数と実行後の戻...
-
VBA でメモ帳へ保存する際の保...
-
ファイル形式またはファイル拡...
-
AccessVBA複数レポート条件毎に...
-
リダイレクトとパイプについて...
-
ファイル出力の場所を指定
-
C言語のプログラムが異常終了し...
-
Base64でエンコードした後の文...
-
I/Oエラー(Delphi)
-
C言語による10進数→16進数変換...
-
CSVファイルを任意の場所に出力...
-
(VBA)書式が変更されてしまい...
-
【ExcelVBA】UTF-8(BOM無)でC...
-
Acccess レポートをグループ別...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
コマンド(例えばls)の出力結果...
-
Acccess レポートをグループ別...
-
ファイル出力の場所を指定
-
VC++でUTF-8のファイルを出力し...
-
ファイル形式またはファイル拡...
-
外国語とCSVについて
-
Wordマクロで指定したフォルダ...
-
AccessVBA複数レポート条件毎に...
-
CreateProcess関数と実行後の戻...
-
pcap形式データをテキストへ抽出
-
テキストファイルに改行コード...
-
ファイル比較について
-
ファイルの文字コードをUTF-8に...
-
CSV形式に変換
-
サウンド出力のデバイスを選択...
-
VBSでEXCEL⇒CSV変換で日付の書...
-
C++ fprintf_sの使い方がわからん
-
VBA でメモ帳へ保存する際の保...
-
VB.NETでExcelファイルを出力す...
-
アクセス>マクロ>テキスト変換
おすすめ情報