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

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

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

VBScript(Visual Basic Scripting Edition)はMicrosftが開発したスクリプト言語であり、Visual Basicのサブセットです。

Q&A

解決済

1回答

826閲覧

監視対象ファイルと、監視VBSのファイルのディレクトリが違う場合の対処方法

oftn

総合スコア19

VBScript

VBScript(Visual Basic Scripting Edition)はMicrosftが開発したスクリプト言語であり、Visual Basicのサブセットです。

0グッド

0クリップ

投稿2019/03/06 06:30

編集2019/03/06 06:33

VBSで、ログローテーションしたファイルの特定の文字列「エラー」を監視していて、検知したときにはメール通知をさせているのですが、
Set tmpFile = WSHFso.OpenTextFile(logfile)
の行で、logfileがみつかりません。というエラーになってしまいます。

監視対象ログファイルが、VBSとは他のファイルにあるのが問題なのかと思うのですが、ファイル構成は変更したくないため、スクリプトのどの部分を変更すればエラーが解決し正常にスクリプトが動くか、お力を貸してください。

ちなみに、同じファイルにログをおいたときは、問題なく動きました。

VBScript

1Dim host 2Dim WshNetwork 3Dim domain 4Dim strMailFrom 5Dim strMailTo 6Dim strSmtpServer 7 8domain = "@domain.co.jp" 9 10'メール送信元にホスト名が自動で入るようにする 11Set WshNetwork = CreateObject("WScript.Network") 12host = WshNetwork.ComputerName 13strMailFrom = host & "_MS" & domain 14 15'メール送信先 16strMailTo = "自分のアドレス" 17 18'SMPTサーバ 19strSmtpServer = "xx.x.x.x" 20 21Set WSHFso = CreateObject("Scripting.FileSystemObject") 22Dim strSearchWord 23Dim errorMsg 24Dim strFormattedDate 25Dim logfile 26 27'日付ごとでログローテーションしたログの監視を実施する 28'yyyy/mm/dd hh:mm:ss 形式の文字列で現在日時を取得 29strFormattedDate = Now() 30 31'yyyy/mm/dd hh:mm:ss から yyyy/mm/dd 部分のみ抽出 32strFormattedDate = Left(strFormattedDate, 10) 33 34'yyyy/mm/dd から / を削除 35strFormattedDate = Replace(strFormattedDate, "/", "") 36 37'読み込みファイルの指定 (相対パスなのでこのスクリプトと同じフォルダに置いておくこと) 38Dim inputFile 39Set inputFile =WSHFso.OpenTextFile("target.lst") 40 41Public Const sWord ="エラー" 42 43'sync_target.txtの一列目を取得してログファイル名に入れるよう、ループをかける 44'さらに、取得したファイルの中に「エラー」がないかもループをかけて監視する 45Do Until inputFile.AtEndOfStream 46Dim lineStr 47lineStr = inputFile.ReadLine 48Dim aryFile 49'最初のスペースまでの一つめだけとる 50aryFile = Split(lineStr, " ") 51 52logfile = "C:\BATCH_LOG\" + strFormattedDate + "_robocopy_" + aryFile(0) + ".log" 53 54Set tmpFile = WSHFso.OpenTextFile(logfile) 55Do Until tmpFile.AtEndOfStream 56 57'1行ずつ読み込み。 58tmpLine = tmpFile.ReadLine 59 60'読み取った1行の中に探している文言があったらエラーで検知した行と次の行を変数に格納する 61 62If InStr(1, tmpLine, sWord, 1) > 0 Then 63errorMsg = errorMsg & aryFile(0) & vbCrLf & tmpLine & vbCrLf & tmpFile.ReadLine & vbCrLf & " " & vbCrLf 64End If 65Loop 66Loop 67 68 69'実行結果が1件以上ある(空ではない)場合はメールを送信して終了 70If Not IsNull(errorMsg) Then 71 dim objMail 72 以下はメール機能

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

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

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

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

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

guest

回答1

0

ベストアンサー

ログが同じフォルダにあるときは問題なかったのであれば、以下で指定しているパスが間違っているのでは。

VBScript

1logfile = "C:\BATCH_LOG\" + strFormattedDate + "_robocopy_" + aryFile(0) + ".log"

例えば以下のようにlogfileを出力してみて、実際のパスと一致しているか確認してみてください。

VBScript

1WScript.Echo logfile

投稿2019/03/06 06:47

ttyp03

総合スコア16998

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

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

oftn

2019/03/06 08:07

パスが誤っていました。ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問