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

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

新規登録して質問してみよう
ただいま回答率
85.48%
コマンド

コマンドとは特定のタスクを行う為に、コンピュータープログラムへ提示する指示文です。多くの場合、コマンドはShellやcmdようなコマンドラインインターフェイスに対する指示文を指します。

コマンドプロンプト

コマンドプロンプト(cmd.exe)はMicrosoftによって提供されているコマンドラインインタプリタです。OS/2・Windows CE・Windows NTで使用可能です。

バッチファイル

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

Q&A

解決済

2回答

2892閲覧

複数のログの中身をテキストファイルとして出力可能なBatchを作成したい。

cat_nyannyan

総合スコア4

コマンド

コマンドとは特定のタスクを行う為に、コンピュータープログラムへ提示する指示文です。多くの場合、コマンドはShellやcmdようなコマンドラインインターフェイスに対する指示文を指します。

コマンドプロンプト

コマンドプロンプト(cmd.exe)はMicrosoftによって提供されているコマンドラインインタプリタです。OS/2・Windows CE・Windows NTで使用可能です。

バッチファイル

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

0グッド

0クリップ

投稿2019/11/12 06:25

編集2019/11/12 08:15

windows10環境にて以下の要件を満たすbatchを作成しようとしています。

※修正

【やりたい事】
ネットワークドライブのフォルダ内に複数存在する全てのテキストログの中身を20分毎にループ参照し、
任意の部分を抜き出してテキストファイルとして出力させたい。
※該当フォルダには20分毎にログが追加されて行きます。

【ネットワークドライブのフォルダ階層】
X:
├data2
└Log
※X:\data2\Log
Logフォルダに対象のログ達とBatchファイルが存在しています。

【入っているログファイル名の例】
LOG_Backup_Subplan_1_20191108040001.txt
LOG_Backup_Subplan_1_20191108042002.txt 等

以下にログの中身を一部抜粋します。

【ログ1】LOG_Backup_Subplan_1_20191108040001.txt
Microsoft(R) Server Maintenance Utility (Unicode) Version 13.0.4451
Command:BACKUP LOG [KP2] TO DISK = N''X:\LOG_Backup\KP2_backup_2019_11_08_040001_0091767.trn'' WITH NOFORMAT, NOINIT, NAME = N''KP2_backup_2019_11_08_040001_0091767'', SKIP, REWIND, NOUNLOAD, COMPRESSION, STATS = 10

【ログ2】LOG_Backup_Subplan_1_20191108042002.txt
Microsoft(R) Server Maintenance Utility (Unicode) Version 13.0.4451
Command:BACKUP LOG [KP2] TO DISK = N''X:\LOG_Backup\KP2_backup_2019_11_08_042001_1705983.trn'' WITH NOFORMAT, NOINIT, NAME = N''KP2_backup_2019_11_08_042001_1705983'', SKIP, REWIND, NOUNLOAD, COMPRESSION, STATS = 10

【現在作成しているスクリプト】
@echo off

pushd X:\data2\Log
set tmp=X:\data2\Log\log_text.txt

:top
timeout 3
dir | find /I "KP2_backup_2019_" LOG_Backup_Subplan_1_.txt >> %tmp%
goto top

上記ログ、Command:部分の
"KP2_backup_2019_~.trn"の部分を20分間に1回のペースで
テキストファイルに定期的に出力させたいのですが、
テキストファイルは出力されますが、
肝心のログの中身が出力出来ない状態です。
解決方法についてご存じの方がいらっしゃいましたら
ご教示いただければ幸甚です。

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

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

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

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

otn

2019/11/12 08:01

set TRN=dir | find /I "KP2_backup_2019_*" LOG_Backup_Subplan_1_*.txt >> %tmp% は、このまま書かれているのですか?であれば、この行の意図は何ですか?詳しく書いてください。
cat_nyannyan

2019/11/12 08:15

すみません、上記ですが実際に書いたもの以外の記載が入っていましたので修正しました。 実際は以下となります。 dir | find /I "KP2_backup_2019_*" LOG_Backup_Subplan_1_*.txt >> %tmp%
guest

回答2

0

ベストアンサー

forfilesコマンドを使えばうまくいくような気がします。
例えば…

batch

1set logfile=X:\data2\Log\log_text.txt 2forfiles /P X:\data2\Log /M "OG_Backup_Subplan_1_*.txt" /C CMD.EXE FINDSTR "KP2_backup_2019_*" @path >> %logfile%

老婆心ながら環境変数"tmp"は、既にシステムで使用されているので別の名前にした方が良いです。
tmpは作業用一時ファイルの作成場所として使用されることが多いため、障害が引き起こすことが予想されるためです。

また、gotoを使用してループさせていますが、この方法は止めることを推奨します。
環境によっては、バッチを停止できなくなることがあります。
20分毎に起動させるならWindowsタスクスケジューラを使用することを進めます。

投稿2019/11/12 13:11

Takeda_Kazuhito

総合スコア369

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

cat_nyannyan

2019/11/13 07:00

回答ありがとうございます。 環境変数やループについてもご教示いただきありがとうございます。 otnさん、takedaさんの回答を参考にさせていただいたところ上手くいきました。
guest

0

dir | find /I "KP2_backup_2019_" LOG_Backup_Subplan_1_.txt >> %tmp%

dir |の意図が不明ですが、findの対象のファイル名を書いたときはfindは標準入力を読みません。

"KP2_backup_2019_*"*の意図が不明ですが、「任意の文字」を意図したのであれば、findにそういう機能はないので、駄目です。

CMD

1find /I "KP2_backup_2019_" LOG_Backup_Subplan_1_*.txt >> %tmp%

ですね。findよりfindstrの方が良い気がしますが。

投稿2019/11/12 08:28

otn

総合スコア84507

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

cat_nyannyan

2019/11/13 06:57

回答ありがとうございます。 findの対象ファイルを記載した際は標準入力を読まない事を認識していませんでした。 findからfindstrにしてコマンド修正したところ希望した通りの挙動になってくれました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問