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

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

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

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

WSH

WSH(Windows Script Host)とは、Windows上でテキストファイルに記述したJavaScriptやVBScriptなどのスクリプトを実行するホスト環境のことです。COMを通じたレジストリ操作やWMIへのアクセスが可能で、複雑な処理も行うことができます。

Q&A

解決済

3回答

26414閲覧

windowsのイベントログのcsvエクスポートについて

kumakumatan

総合スコア213

コマンド

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

WSH

WSH(Windows Script Host)とは、Windows上でテキストファイルに記述したJavaScriptやVBScriptなどのスクリプトを実行するホスト環境のことです。COMを通じたレジストリ操作やWMIへのアクセスが可能で、複雑な処理も行うことができます。

0グッド

1クリップ

投稿2016/01/20 02:35

WindowsXP/Windows7 のクライアントPCにて、イベントログ(6005:起動時間)、
(6006:シャットダウン時間)の情報をCSVファイルなどに出力したいと考えています。

対象は300台くらいあるので、スクリプトを作成して実行したいと考えています。
できれば、出力したログファイルにPC名などの情報も出力したいと考えています。

自分なりに、「wevtutil qe system /f:text /q:*[System[(EventID=%6005)]] > c:\ivent.txt」
などでしてみたのですが、
「位置 18 で構文エラーが発生しました。
イベント クエリを開けませんでした。 指定されたクエリは無効です。」
のエラーが出て、出力できません。

どなたかご教授いただければ幸いです。

宜しくお願い致します。

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

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

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

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

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

guest

回答3

0

ベストアンサー

%6005%が不要と思います

wevtutil qe system /f:text /q:"*[System[(EventID=6005)]]" > c:\ivent.txt

これで実行できました

6006も含めるならこんな感じ
クエリは""で括ります

wevtutil qe system /f:text /q:"*[System[(EventID=6005 or EventID=6006)]]" > c:\ivent.txt


(XP マシンの場合)

cscript c:\windows\system32\eventquery.vbs /v /FI "Id eq 6005 or Id eq 6006" /l system >c:\evt-system.txt

投稿2016/01/20 03:11

編集2016/01/20 05:03
takito

総合スコア3116

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

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

kumakumatan

2016/01/20 04:16

ありがとうございます。Windows7ではできました。しかし、WindowsXpのPCがあり、 その場合はどうしたらいいでしょうか?WindowsXPには、「C:\WINDOWS\system32\eventquery.vbs」があるみたいですがそれを利用して何かできませんか?? 宜しくお願いします。
takito

2016/01/20 04:59

XPの場合はおっしゃるように eventquery.vbs をお使いになれば取れます 例を元投稿の方に追記しますね
guest

0

■Windows7
wevtutil qe system /f:text /q:"*[System[(EventID=6005 or EventID=6006)]]" > c:\ivent.csv

■WindowsXp
Cscript "C:\WINDOWS\system32\eventquery.vbs" /l System /FI "Id eq 6005 or Id eq 6006" /FO List /V > c:\ivent.csv

にてやりたい事ができました。
後はコマンドにてOS判定して、処理を分けたいと思います。

ご回答いただいた皆様ありがとうございました。

投稿2016/01/20 04:43

kumakumatan

総合スコア213

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

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

0

シャットダウン時のイベントログのIDですが異常終了した場合は6008が次回起動時に記録され、メッセージにシャットダウンの時刻が書き込まれます。
以前のシステム シャットダウン ( ‎2015/‎12/‎07 9:50:18) は予期されていませんでした。
[NT] イベント 6005、6006、6008、6009 がログに記録される

PowerShellを使用した方法を書いてみます。
Get-EventLog
Windows PowerShell でイベントログを取得する - ひまわりのむく方向

# ローカルマシン Get-EventLog System | select EventID,MachineName,TimeWritten,Message | ? {$_.EventID -eq 6005 -or $_.EventID -eq 6006 -or $_.EventID -eq 6008 } # リモートマシン Get-EventLog System -ComputerName マシン名1,マシン名2 | select EventID,MachineName,TimeWritten,Message | ? {$_.EventID -eq 6005 -or $_.EventID -eq 6006 -or $_.EventID -eq 6008 } # CSV出力 Get-EventLog System | select EventID,MachineName,TimeWritten,Message | ? {$_.EventID -eq 6005 -or $_.EventID -eq 6006 -or $_.EventID -eq 6008 } | Export-Csv 出力ファイルパス

投稿2016/01/20 03:56

sho_cs

総合スコア3541

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

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

kumakumatan

2016/01/20 04:18

ありがとうございます。 PoweShellは現在、運用上利用しないので、今後のご参考にさせていただきます。 ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.37%

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

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

質問する

関連した質問