schauan
Goto Top

Filestatus (1) mit VBS auswerten ? Fehler Zugriffsverletzung vermeiden

Hallöchen,

ich habe im Moment ein Problem mit einem File. Ein Script bleibt immer hängen weil das File angeblich von irgendeinem Programm genutzt wird. Ich würde das File dann gern übergehen.

Im Script kommt der Fehlercode 800A0046, Erlaubnis verweigert.

Ich kann in die Datei schreiben. Ich kann die Datei nicht umbenennen und nicht löschen. Die Datei ist nicht schreibgeschützt.

Ich habe den Filestatus mangels besserem Wissen statt in VBS in VBA geprüft und erhalte dort einen Rückgabewert 1. 0 wäre geschlossen, 70 geöffnet.
...
    Open xlFile For Binary Access Read Lock Read As #File
...
        Case 0: FileStatus = XL_CLOSED
        Case 70: FileStatus = XL_OPEN
        Case 76: FileStatus = XL_DONTEXIST
        Case Else: FileStatus = XL_UNDEFINED
...

Wie kann man das in VBS prüfen?

Content-ID: 79045

Url: https://administrator.de/forum/filestatus-1-mit-vbs-auswerten-fehler-zugriffsverletzung-vermeiden-79045.html

Ausgedruckt am: 09.01.2025 um 15:01 Uhr

bastla
bastla 24.01.2008 um 14:48:03 Uhr
Goto Top
Hallo schauan!

Wie kann man das in VBS prüfen?
Dass eine derartige Prüfung möglich ist, bezweifle ich; Du könntest aber ein "On Error Resume Next" vor dem Zugriff und ein "If Err.Number <> 0 Then ..." nach der entsprechenden Zeile platzieren und den Fehler damit abfangen.

Grüße
bastla
schauan
schauan 25.01.2008 um 07:21:32 Uhr
Goto Top
Hallo basta,

danke erst mal, aber das ist nicht so einfach. Ich stelle mit dem File einiges an. Zuerst erstelle ich eine Sicherheitskopie. Dann entnehme ich einige Daten, und schreibe ein paar andere hinein. Die entnommenen Daten werden in eine Datenbank eingetragen. Dazu laufen mehrere Scripte und Programme. Das geht ja alles noch.

Erst wenn diese Aktionen erfolgreich waren wird das File umbenannt. Es erhält eine andere Erweiterung, u.a. auch, damit ich es nicht noch ein mal in den Prozess gebe.

Um den Fehler abzufangen müsste ich das File erst umbenennen, dann wieder den alten Namen einsetzen, dann meine restlichen Arbeiten ausführen und dann das File als "Erfolgskontrolle" wieder umbenennen.

Warum einfach, wenns umständlich geht ... Vielleicht kann WMI so was, das kann man auch in VBS verwenden?
bastla
bastla 25.01.2008 um 08:23:52 Uhr
Goto Top
Hallo schauan!

WMI ist eine gute Idee - Du könntest es vielleicht mit dem Property "InUseCount" der CIM_DataFile Class versuchen.

Beispielcode dafür:
strComputer = "."   
Set objWMIService = GetObject("winmgmts:\\" & strComputer & "\root\CIMV2")   
Set colItems = objWMIService.ExecQuery( _
    "SELECT * FROM CIM_DataFile WHERE Name = " _  
        & "'D:\\DeinFolder\\DeinFile.Ext'")   
For Each objItem in colItems 
    WScript.Echo "InUseCount: " & objItem.InUseCount  
Next
Ansonsten wäre da noch (zum Umbenennen) die CIM_FileAction Class ...

Grüße
bastla
schauan
schauan 28.01.2008 um 15:40:29 Uhr
Goto Top
Hallo bastla
habe es getestet, funktioniert leider nicht. Als Ergebnis bekomme ich ausser
InUseCount:
auf der Meldung nichts. Ich habe den code mal nach VBA genommen um die Objekte zu prüfen. In objitem steht auch allerhand drin. Der InUseCount findet sich bei den Properties im 23. Item. Leider immer mit Null, egal was ich für ein File nehme.
Getestet habe ich es z.B. mit einem Outlock-Postfach. Selbiges ließ sich wegen dem Zugriff durch das Mail im Explorer nicht umbenennen.
Grüße, Andre
bastla
bastla 28.01.2008 um 16:00:03 Uhr
Goto Top
Hallo Andre!

Einen hab ich noch: How do I rename a file without getting an error message? (auch nicht getestet, insbes hinsichtlich Performance) ...

... oder eben doch "On Error Resume Next".

Grüße
bastla
schauan
schauan 14.09.2009 um 07:48:12 Uhr
Goto Top
Hallo bastla,

Danke für die Hinweise,
Trotz aller versuche lief es nicht stabil genug face-sad Ich mache es daher inzwischen anders. Ich handle meine Aktionen nicht mehr über das File, sondern über die Datenbank und einige Informationen aus dem Filesystem. Dann wird einfach ein neues File erzeugt. Dadurch bin ich nicht mehr "ewig" im File und habe bislang keine Konflikte mehr.