
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制作)
-
コマンドプロンプトの「%1」と「%~1」の違いがわからない
その他(プログラミング・Web制作)
-
runas実行した時にきかれるパスワードを手入力以外で読み込ませたい
その他(プログラミング・Web制作)
-
-
4
Dirコマンドでフォルダ内ファイルの合計サイズをだすには?(コマンドプロンプトにて)
UNIX・Linux
-
5
Dosブロンプトでtabを出力したい
その他(プログラミング・Web制作)
-
6
バッチファイル内の各コマンドが順番に実行される条件
その他(OS)
-
7
コマンドプロンプトのエラーについて
その他(パソコン・周辺機器)
-
8
Windowsのバッチファイルで正規表現の置換方法について…
Windows 10
-
9
テキストファイルから最終行の抽出
Windows Me・NT・2000
-
10
シェルスクリプトでオラクルのエラーメッセージを取得するには
Oracle
-
11
COPYコマンドで結合すると余計な改行コードができる
その他(プログラミング・Web制作)
-
12
バッチでテキストファイルから任意の行のみ取得したい
その他(プログラミング・Web制作)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
VB2010でCSVファイルの読み込み
-
Escキーを押すと、中断する時と...
-
CSVファイルの特定の行だけを読...
-
アクティブセルから、A列最終行...
-
VBA for i=1 to lastrow
-
VBAでの一時停止と再開の方法
-
レインボー色ってどうやって表...
-
乱数の桁数指定、または範囲指定。
-
GIFアニメをループさせたくない
-
範囲指定したセルを1つずつ飛...
-
VBAで3秒だけ時間を止めたい
-
画面を強制的に再描画させる方法
-
EXCEL VBA ユーザーフォームの...
-
流れ図(フローチャート)が分か...
-
テキストボックスの名前に変数...
-
alarmの使用について
-
Do whileでExitせず、ループの...
-
vb.netです。2次元配列の要素を...
-
変数の扱える範囲
-
null 参照の例外が実行時に発生...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
UWSCの終了の仕方
-
画面を強制的に再描画させる方法
-
Escキーを押すと、中断する時と...
-
範囲指定したセルを1つずつ飛...
-
vb.netです。2次元配列の要素を...
-
VBAで3秒だけ時間を止めたい
-
エクセルの当番表を作っていま...
-
UWSCに制限時間を付けたいです
-
DOSコマンドのループ内のTIMEコ...
-
VBAでの一時停止と再開の方法
-
CSVファイルの特定の行だけを読...
-
DoEventsが必要な理由について
-
GIFアニメをループさせたくない
-
VBA for i=1 to lastrow
-
Do whileでExitせず、ループの...
-
VBA Boxが空白の場合のメッセー...
-
vb.netからエクセル関数書き込み
-
イベントの発生を待つ
-
乱数の桁数指定、または範囲指定。
-
エクセル関数で1〜12の数字がル...
おすすめ情報