ExcelWork.info

日付時刻:経過時間を取得( Timer 関数 )

Timer 関数の使い方


【書式】

result = Timer ()


【戻り値】

  • result  ・・・  当日午前 0 時から経過した秒数を表す単精度浮動小数点数型(Single)の値。


Timer 関数は、処理中に午前0時を超えた場合、値を「1日の総秒数を反転した値(-86,400 秒)」にリセットし、そこから経過秒数を加算していきます。さらに1日が経過し翌日の午前0時になると「 0 秒」となるので、日付をまたぐ場合は注意が必要です。
【対応策】
1.経過時間の差分の値の絶対値を Abs 関数等で算出して、その値で経過秒数を判定する。
2.「【参考】サンプルVBAソース2」のように、Timar 関数を使用しない。


Timer 関数の使用例

サンプルVBAソース


実行結果


DoEvents 関数について
上記マクロ内には DoEvents というのがありますが、この「DoEvents関数」を使用することで、一時的に、他のアプリケーションが実行できるように Windows に制御を移すことが可能になります。
つまり、マクロを実行後、VBE 画面からマクロを停止することが可能になります。



【参考】サンプルVBAソース2