データをcsvファイ​ルに書き込む際に書き​込み完了を検知したい

15 views (last 30 days)
HIronori Kamachi
HIronori Kamachi on 7 Aug 2019
Commented: Kazuya on 8 Aug 2019
2つのファイルを同時に走らせています。
片方のファイル(AAA.m)の動作は、
1.trigger.csvファイルが存在することを確認する(1回目はスキップ)
2.データファイルの上から順にデータを読み出し、そのデータをquery.csvに書き出す
3.trigger.csvファイルを消去
これをループしています
もう片方のファイル(BBB.m)は
1.query.csvファイルが存在することを確認(exist)
2.query.csvファイルのデータをtrigger.csvファイルにコピー(copyfile)
3.データ(data = dlmread('query.csv'))を使って計算を実行
これをループしています。
この2つのファイルが並行して計算を実行しているのですが、たまにエラーが起きてストップします。
どうも、AAA.mからquery.csvファイルができて、データが書き込まれるよりも早いタイミングで
BBB.mがquery.csvファイルのデータをコピーに行くために、query.csv中にデータがなくて
止まってしまっているようです。
(ファイルの末尾に空の形式文字ベクトルを使用することはできません, のメッセージあり)
回避する手段として、AAA.mによるquery.csvのデータ書き込みが終了した時点でフラグを立てるか何かして、
そのフラグを見てBBB.mがquery.csvのデータを読みに行くようにしたいと考えていますが、
やり方がわかりません。
何か良い方法はないでしょうか。

Accepted Answer

Kazuya
Kazuya on 7 Aug 2019
Edited: Kazuya on 7 Aug 2019
根本的な解決策ではないですが、例えば
flag = true;
while flag
try
%「BBB.mがquery.csvファイルのデータをコピーに行く」に、query.csv中にデータがなくてエラー
catch ME
flag = true;
end
flag = false;
end
と try/catch の構文で、エラーがでずに BBB.m が実行できるまで while ループで回すという方法はいかがでしょう。
それでも「エラーは出ないが、意図している結果にならない」=「データ書き込みが中途半端」である可能性も残りますね。書き込みが完了したときのデータ量が事前に把握できていれば、その情報を使って成否を判断するのはどうでしょう。
  2 Comments
HIronori Kamachi
HIronori Kamachi on 7 Aug 2019
とりあえず、前者のwhileループとtry/catch構文で今のところうまくいきそうです。
try/catchは以前別件でここで教えていただいていた?と思うのですが、応用ができていないなあ。反省しきりです。
どうもありがとうございました。
Kazuya
Kazuya on 8 Aug 2019
とんでもないです。うまくいきそうで良かったです。

Sign in to comment.

More Answers (0)

Categories

Find more on プログラミング in Help Center and File Exchange

Products

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!