ファイルを作成しようとするときに、このVBScriptがエラーを投げるのはなぜですか?

StackOverflow https://stackoverflow.com/questions/5399326

質問

私はこのスクリプトを見つけました、そして、ファイルを作成しようとするときにそれがエラーをスローする理由を理解できないようです C:\IPSecWeights.xls.

私がこれまでに問題を抱えているラインは次のとおりです。

Set objWorkbook = objExcel.Workbooks.Open(FileLoc)

ファイルが見つからなかったというエラーがあります。これを修正するためにコードを書き換えるにはどうすればよいですか?

Const ForReading = 1
Const ForWriting = 2
Const ForAppending = 8
Dim objFSO,objFile
Dim arrLines
Dim strLine
Dim objExcel,objWorkbook
Dim FileLoc
Dim intRow
Dim objDictionary

FileLoc = "C:\IPSecWeights.xls"

Sub ExcelHeaders()
    Set objRange = objExcel.Range("A1","G1")
    objRange.Font.Size = 12
    objRange.Interior.ColorIndex=15

    objexcel.cells(1,1)="Filter Name"
    objexcel.cells(1,2)="Source"
    objexcel.cells(1,3)="Destination"
    objexcel.cells(1,4)="Source Port"
    objexcel.cells(1,5)="Destination Port"
    objexcel.cells(1,6)="Protocol"
    objexcel.cells(1,7)="Direction"
End Sub

Function RegExFind(strText,strPattern)
    Dim regEx
    Dim match, Matches
    Dim arrMatches
    Dim i : i = 0
    Set regEx = New RegExp
    regEx.IgnoreCase = True
    regEx.Global = True
    regEx.Pattern = strPattern

    Set matches = regEx.Execute(strText)
    ReDim arrMatches(Matches.Count)
    For Each match In Matches
        For Each SubMatch In match.Submatches
            arrMatches(i) = Submatch
            i = i + 1
        Next
    Next
    RegExFind = arrMatches
End Function


Set objFSO = CreateObject("Scripting.FileSystemObject")
Set objFile = objFSO.OpenTextFile(WScript.Arguments(0),ForReading)

Set objExcel = CreateObject("excel.application")
Set objWorkbook = objExcel.Workbooks.Open(FileLoc)

objExcel.Visible = True

ExcelHeaders ' Create Excel Headers

rePolicy = "Policy Name\s+:\s(.+)"
reSRCAddr = "Source Address\s+:\s(.+)"
reDSTAddr = "Destination Address\s+:\s(.+)"
reProtocol = "Protocol\s+:\s(.+)"
reSRCPort = "Source Port\s+:\s(.+)"
reDSTPort = "Destination Port\s+:\s(.+)"
reDirection = "Direction\s+:\s(.+)"

strText = objFile.ReadAll
objFile.Close

Dim arrPolicy, arrSRCAddr, arrDSTAddr, arrProtocol, arrSRCPort, arrDSTPort, arrDirection

arrPolicy = RegExFind(strText, rePolicy)
arrSRCAddr = RegExFind(strText, reSRCAddr)
arrDSTAddr = RegExFind(strText, reDSTAddr)
arrProtocol = RegExFind(strText, reProtocol)
arrSRCPort = RegExFind(strText, reSRCPort)
arrDSTPort = RegExFind(strText, reDSTPort)
arrDirection = RegExFind(strText, reDirection)

intRow = 2

For i = 0 To UBound(arrPolicy)
    objExcel.Cells(introw,1) = arrPolicy(i)
    objExcel.Cells(introw,2) = arrSRCAddr(i)
    objExcel.Cells(introw,3) = arrDSTAddr(i)
    objExcel.Cells(introw,4) = arrSRCPort(i)
    objExcel.Cells(introw,5) = arrDSTPort(i)
    objExcel.Cells(introw,6) = arrProtocol(i)
    objExcel.Cells(introw,7) = arrDirection(i)

    intRow = intRow + 1
Next

objFile.Close
objWorkbook.save
'objExcel.Quit
役に立ちましたか?

解決

「ファイルが見つかっていない」は、やや誤解を招くエラーメッセージであると思います。 つまり、あなたの 実際 問題はファイルシステムの権限ですが、VBScriptは、これをより賢明なエラーではなく「ファイルが見つかっていない」と頑固に報告しています。

おそらく、スクリプトは以前のバージョンのWindowsで正常に機能しましたが、Vistaを使用してコンピューターで試しているか、後でインストールされているため、多くの追加のセキュリティ機能と書き込み保護が導入されています。 ユーザーアカウントコントロール(UAC) アプリケーションやスクリプトをハードディスクのルートレベルに書き込ませません。

もちろん、これは本当に問題ではないはずです。合法的なアプリケーションには、ハードドライブのルートレベルや共有システムフォルダーのファイルを改ざんする必要がないため( C:\Windows)、しかし、テスト中に時々現れる。

スクリプト内のファイルパスを変更して、「私のドキュメント」フォルダーのように、読み取り/書き込みアクセスがあることが保証されています。展開のために、とにかくファイルシステムパスをハードコードしてはいけません。使用 GetSpecialFolder 関数FileSystemObject 代わりに、パスを取得します。

ライセンス: CC-BY-SA帰属
所属していません StackOverflow
scroll top