質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

90.50%

  • Windows

    1442questions

    Windowsは、マイクロソフト社が開発したオペレーティングシステムです。当初は、MS-DOSに変わるOSとして開発されました。 GUIを採用し、主にインテル系のCPUを搭載したコンピューターで動作します。Windows系OSのシェアは、90%を超えるといわれています。 パソコン用以外に、POSシステムやスマートフォンなどの携帯端末用、サーバ用のOSもあります。

  • バッチファイル

    223questions

    バッチファイル(Batch File)は、Windowsのコマンドラインインタープリターによって複数のコマンドを実行させる事が出来るスクリプトファイルです。

バッチファイル ループ処理について

受付中

回答 2

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 342

pipi

score 145

各ファイルのコピー時間を計測時間をも求めるバッチを作成しているのですが、
なかなかうまく行きません。

<仕様>
C:\work\01_学習資料\01_Windows\bat\tmp\
にある01-1G.dat、02-1M.dat、03-5M.datファイルを

C:\work\01_学習資料\01_Windows\bat\tmp1\
へ1つ1つコピーしてコピー時間を秒単位で求めます。

@echo off

set LogPath=C:\work\01_学習資料\01_Windows\bat\tmp\
set SrcPath=C:\work\01_学習資料\01_Windows\bat\tmp\
set DstPath=C:\work\01_学習資料\01_Windows\bat\tmp1\

rem 1Gファイルコピー時間計測
set S_time_tmp=%time: =0%
set hh=%S_time_tmp:~0,2%
set mi=%S_time_tmp:~3,2%
set ss=%S_time_tmp:~6,2%
set sss=%S_time_tmp:~9,2%
set S_datetime=%hh%%mi%%ss%

echo 開始:%S_datetime% > %LogPath%01_%S_datetime%.log 
copy %SrcPath%01-1G.dat %DstPath%

rem 終了時刻設定
set E_time_tmp=%time: =0%
set hh=%E_time_tmp:~0,2%
set mi=%E_time_tmp:~3,2%
set ss=%E_time_tmp:~6,2%
set sss=%E_time_tmp:~9,2%
set E_datetime=%hh%%mi%%ss%

echo 終了:%E_datetime% >> %LogPath%01_%S_datetime%.log

timeout 2 > null


rem 1Mファイルコピー時間計測
set S_time_tmp=%time: =0%
set hh=%S_time_tmp:~0,2%
set mi=%S_time_tmp:~3,2%
set ss=%S_time_tmp:~6,2%
set sss=%S_time_tmp:~9,2%
set S_datetime=%hh%%mi%%ss%

echo 開始:%S_datetime% > %LogPath%02_%S_datetime%.log 
copy %SrcPath%02-1M.dat %DstPath%

rem 終了時刻設定
set E_time_tmp=%time: =0%
set hh=%E_time_tmp:~0,2%
set mi=%E_time_tmp:~3,2%
set ss=%E_time_tmp:~6,2%
set sss=%E_time_tmp:~9,2%
set E_datetime=%hh%%mi%%ss%

echo 終了:%E_datetime% >> %LogPath%02_%S_datetime%.log

timeout 2 > null

rem 5Mファイルコピー時間計測
set S_time_tmp=%time: =0%
set hh=%S_time_tmp:~0,2%
set mi=%S_time_tmp:~3,2%
set ss=%S_time_tmp:~6,2%
set sss=%S_time_tmp:~9,2%
set S_datetime=%hh%%mi%%ss%

echo 開始:%S_datetime% > %LogPath%03_%S_datetime%.log 
copy %SrcPath%03-5M.dat %DstPath%

rem 終了時刻設定
set E_time_tmp=%time: =0%
set hh=%E_time_tmp:~0,2%
set mi=%E_time_tmp:~3,2%
set ss=%E_time_tmp:~6,2%
set sss=%E_time_tmp:~9,2%
set E_datetime=%hh%%mi%%ss%

echo 終了:%E_datetime% >> %LogPath%03_%S_datetime%.log

上記コードでは、100ファイルあったっら非常に非効率になってしまうことは重々承知です。
ループを使ってなんとしたいのですが・・・・

一応、一つ一つ分解し簡略化した動作を確認しています。
まずは、コピー元フォルダ内のファイルが取得できるか確認。↓

@echo off

cd C:\work\01_学習資料\01_Windows\bat\tmp

for %%i in (*.dat) do (
    echo %%i
)

そして、以下のようにループで取得したファイル名をパスに連結すると
エラーとなってしまいます。%%1には、ファイル名が入っているので、

copy %SrcPath%%%i % DstPath%


としても大丈夫なような気もするのですが・・・・

@echo off

set LogPath=C:\work\01_学習資料\01_Windows\bat\tmp\
set SrcPath=C:\work\01_学習資料\01_Windows\bat\tmp\
set DstPath=C:\work\01_学習資料\01_Windows\bat\tmp1\

cd %SrcPath%


for %%i in (*.dat) do (
    rem echo %%i
    copy %SrcPath%%%i % DstPath% 
)
pause

11:24 追記↓
試行錯誤して下記の様に変更したら、1ファイルずつコピーできるようになりましたが、
logファイルがうまく生成されません。
logファイルは、log-YYYYMMDDSS.logという形式で出力させたいのですが、なぜか、
log-.logというファイルが1ファイルしか出来上がりません。

@echo off

set LogPath=C:\work\01_学習資料\01_Windows\bat\tmp\
set SrcPath=C:\work\01_学習資料\01_Windows\bat\tmp\
set DstPath=C:\work\01_学習資料\01_Windows\bat\tmp1\

cd %SrcPath%


for %%i in (*.dat) do (
    rem echo %%i

    set S_time_tmp=%time: =0%
    set hh=%S_time_tmp:~0,2%
    set mi=%S_time_tmp:~3,2%
    set ss=%S_time_tmp:~6,2%
    set S_datetime=%hh%%mi%%ss%

rem logファイル生成
    echo PC→XXServer > %LogPath%log-%S_datetime%.log 
    echo CopyFileName: %%i >> %LogPath%log-%S_datetime%.log 
    echo 開始時刻:%S_datetime% >> %LogPath%log-%S_datetime%.log 

    copy %%i %DstPath%

    set E_time_tmp=%time: =0%
    set hh=%E_time_tmp:~0,2%
    set mi=%E_time_tmp:~3,2%
    set ss=%E_time_tmp:~6,2%
    set E_datetime=%hh%%mi%%ss%

    echo 終了時刻:%E_datetime% >> %LogPath%log-%S_datetime%.log

    timeout /T 2 > null
)

pause


アドバイスの程、よろしくお願い致します。

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 2

+1

% DstPath%

の部分のスペースがおかしいかと

%DstPath%

としないとコピー先の指定がおかしくなります。

 追記

for内の環境変数に関しては「遅延環境変数」について調査されるとよいかと思います。
ただ、そうするよりは、下記のようにfor内を別のバッチファイルとしたほうがすっきりするかと
思います。

バッチ1

set DstPath=C:\dest

for %%i in (*.*) do (

バッチ2 %%i %DstPath%

)

pause


バッチ2

set LogPath=C:\log\

set S_time_tmp=%time: =0%

copy %1 %2

set E_time_tmp=%time: =0%

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

+1

forの中をサブルーチンにしてください。

for %%i in (*.dat) do call :SUB %%i
pause
exit /b
:SUB
    rem echo %1

    set S_time_tmp=%time: =0%
    set hh=%S_time_tmp:~0,2%
    set mi=%S_time_tmp:~3,2%
    set ss=%S_time_tmp:~6,2%
    set S_datetime=%hh%%mi%%ss%

rem logファイル生成
    echo PC→XXServer > %LogPath%log-%S_datetime%.log 
    echo CopyFileName: %1 >> %LogPath%log-%S_datetime%.log 
    echo 開始時刻:%S_datetime% >> %LogPath%log-%S_datetime%.log 

    copy %1 %DstPath%

    set E_time_tmp=%time: =0%
    set hh=%E_time_tmp:~0,2%
    set mi=%E_time_tmp:~3,2%
    set ss=%E_time_tmp:~6,2%
    set E_datetime=%hh%%mi%%ss%

    echo 終了時刻:%E_datetime% >> %LogPath%log-%S_datetime%.log

    timeout /T 2 > null


あと、1つのファイルのコピーが1秒以内で終わると、ログファイル名が重複して上書きされるので、追記にした方が良いと思います。
echo PC→XXServer >> %LogPath%log-%S_datetime%.log

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 90.50%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る

  • Windows

    1442questions

    Windowsは、マイクロソフト社が開発したオペレーティングシステムです。当初は、MS-DOSに変わるOSとして開発されました。 GUIを採用し、主にインテル系のCPUを搭載したコンピューターで動作します。Windows系OSのシェアは、90%を超えるといわれています。 パソコン用以外に、POSシステムやスマートフォンなどの携帯端末用、サーバ用のOSもあります。

  • バッチファイル

    223questions

    バッチファイル(Batch File)は、Windowsのコマンドラインインタープリターによって複数のコマンドを実行させる事が出来るスクリプトファイルです。