
DOSコマンドのループ内のTIMEコマンド
ループの中で、少し時間のかかる処理を連続的に行ない、さらに時刻表示を行い
1回あたりの時間が分かるように表示したいと思っています。
下記のソースのイメージです。(極めてシンプルにしました)
しかし、ループ内で実行するtimeコマンドがすべて同じ
時刻になってしまい、意図通りの動きになりません。
ループ内で、ループごとに異なる時刻を表示することは可能でしょうか?
もしできるのであればその方法を教えてください。
よろしくお願いします。
@echo start◆%time%
@FOR /L %%I IN (0, 1, 3) DO @(
@echo %%I【%time%】
@ping localhost -n 2 > nul
)
@echo end ◆%time%
pause
No.1ベストアンサー
- 回答日時:
ループの前に
setlocal enabledelayedexpansion
と書いておいて、ループの中では
%time%の代わりに!time!を使いましょう。
「setlocal enabledelayedexpansion」
これはさっぱり分かりませんでした。なんか長いし。
しかし言われるがままに修正したら意図通りに動きました。
非常にびっくりしました。
とりあえず調べてみたところ、遅延展開云々
という仕様があることをはじめて知りました。
これは経験の差ですね。非常に助かりました。
質問して本当によかったです。
ありがとうございました。
No.3
- 回答日時:
#1の回答のようにするか
コマンドプロンプトを起動する際に /V:ON を追加して !time!を使ってみましょう
No.2
- 回答日時:
forループの中ではforコマンド起動時の時刻しか帰らないようですね。
1つの方法としては、以下のようにcallで飛ばしてやるという方法があります。
@echo start◆%time%
@FOR /L %%I IN (0, 1, 3) DO @call :sub
@echo end ◆%time%
pause
@goto :eof
:sub
@echo %%I【%time%】
@ping localhost -n 2 > nul
@exit /b
ご提示していただいた方法ですと、
たしかにtimeコマンドは意図通り動くのですが、
subの処理はループと無関係と判断されてしまう為に
ループのインデックスの表示は出来ないようです…。
しかし、遅延展開問題の回避方法の1つとして
サブルーチン(?)を使えばいいということがわかりました。
またそもそも、DOSバッチにサブルーチンがあることを
知らなかったのでその点でも参考になりました。
ありがとうございました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
バッチファイルで常に最新の現在時刻を表示したい
その他(プログラミング・Web制作)
-
Dosブロンプトでtabを出力したい
その他(プログラミング・Web制作)
-
バッチファイル内の各コマンドが順番に実行される条件
その他(OS)
-
-
4
コマンドプロンプトの「%1」と「%~1」の違いがわからない
その他(プログラミング・Web制作)
-
5
Windowsのバッチファイルで正規表現の置換方法について…
Windows 10
-
6
runas実行した時にきかれるパスワードを手入力以外で読み込ませたい
その他(プログラミング・Web制作)
-
7
COPYコマンドで結合すると余計な改行コードができる
その他(プログラミング・Web制作)
-
8
Dirコマンドでフォルダ内ファイルの合計サイズをだすには?(コマンドプロンプトにて)
UNIX・Linux
-
9
コマンドプロンプトのエラーについて
その他(パソコン・周辺機器)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
画面を強制的に再描画させる方法
-
UWSCの終了の仕方
-
UWSCのスクリプトで行き詰って...
-
VBAでこの様なコード時のセルの...
-
流れ図(フローチャート)が分か...
-
VBAでの一時停止と再開の方法
-
UWSCに制限時間を付けたいです
-
VB2010でCSVファイルの読み込み
-
範囲指定したセルを1つずつ飛...
-
objective-cの多重ループbreak
-
エクセルの当番表を作っていま...
-
ExcelVBAで、index、match関数...
-
「偶数・奇数の和」のフローチ...
-
リストボックスに縦スクロール...
-
RFC822形式の日付を生成するサ...
-
一致する要素が格納されている...
-
ハッシュ値が一致したデータは...
-
VBのReturnの使い方
-
ハッシュ検索はなぜ速い
-
短いハッシュの作り方
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
画面を強制的に再描画させる方法
-
UWSCの終了の仕方
-
CSVファイルの特定の行だけを読...
-
範囲指定したセルを1つずつ飛...
-
UWSCに制限時間を付けたいです
-
Escキーを押すと、中断する時と...
-
乱数の桁数指定、または範囲指定。
-
VBA for i=1 to lastrow
-
流れ図(フローチャート)が分か...
-
DOSコマンドのループ内のTIMEコ...
-
pythonでファイルのコメント行...
-
素数表について。
-
VBAでの一時停止と再開の方法
-
「偶数・奇数の和」のフローチ...
-
DoEventsが必要な理由について
-
vb.netです。2次元配列の要素を...
-
Do whileでExitせず、ループの...
-
ループフリー
-
エクセルの当番表を作っていま...
-
VBAで3秒だけ時間を止めたい
おすすめ情報