VBScript Fehler mit If OK dann beenden Else Installation starten
Probleme mit der Abfrage für eine Installation.
Hallo Liebes Forum
Ich habe folgendes Script:
Danke danke danke allen.
Gruss Majce
Hallo Liebes Forum
Ich habe folgendes Script:
Dim oFSO, oApp, oFolderCopy, oShell
Dim strFontsPath, strScriptPath
Set oFSO = CreateObject("Scripting.FileSystemObject")
Set oShell = CreateObject("WScript.Shell")
Set oApp = CreateObject("Shell.Application")
strScriptPath = WScript.ScriptFullName
strScriptPath = left(strScriptPath,instrrev(strScriptPath,"\"))
strFontsPath = oShell.ExpandEnvironmentStrings("%WINDIR%") & "\Fonts"
Set oFolderCopy = oApp.Namespace(strScriptPath & "FontsToInstall")
For Each oFont In oFolderCopy.Items
IF oFSO.FileExists(strFontsPath & "\" & oFont.Name) Then End If
Else
oApp.Namespace(strFontsPath).CopyHere oFont
End If
Next
' Cleanup Objects
Set oFolderCopy = Nothing
Set oApp = Nothing
Set oShell = Nothing
Mein Problem liegt beim Punkt:
IF oFSO.FileExists(strFontsPath & "\" & oFont.Name) Then End If
Else
oApp.Namespace(strFontsPath).CopyHere oFont
End If
Egal was ich mache, es kommt immer eine Fehlermeldung.
Und wenn ich es nicht beende, dann wird der User 500x gefragt, ob er die Schriftart ersetzen will, weil es diese schon hat.
Ich bitte um Hilfe, da ich mich mit VB überhaupt nicht auskenne.
Es sollte so aussehen:
IF Schriftart vorhanden THEN beende die Abfrage
ELSE
installiere die Schriftart.
END If
Gruss Majce
Bitte markiere auch die Kommentare, die zur Lösung des Beitrags beigetragen haben
Content-ID: 171502
Url: https://administrator.de/contentid/171502
Ausgedruckt am: 22.11.2024 um 21:11 Uhr
15 Kommentare
Neuester Kommentar
Hallo Majce,
versuche doch bitte mal folgende Stelle abzuändern:
in:
Gruss,
Robob.
versuche doch bitte mal folgende Stelle abzuändern:
IF oFSO.FileExists(strFontsPath & "\" & oFont.Name) Then End If
Else
oApp.Namespace(strFontsPath).CopyHere oFont
End If
IF NOT oFSO.FileExists(strFontsPath & "\" & oFont.Name) Then
oApp.Namespace(strFontsPath).CopyHere oFont
End If
Robob.
Das verstehe ich jetzt nicht, denn die Zeile würde ja durch das "NOT" eigentlich bedeuten, wenn die Datei NICHT vorhanden ist, dann kopiere die Schriftart ansonsten tue nichts innerhalb der IF-Schleife...
Ich teste das jetzt kurz mal an meinem Notebook und melde mich dann wieder, wenn hoffentlich nichts dazwischen kommt...
Gruss,
Robob.
Ich teste das jetzt kurz mal an meinem Notebook und melde mich dann wieder, wenn hoffentlich nichts dazwischen kommt...
Gruss,
Robob.
Hallo Majic,
also bei mir funktioniert der geänderte Code ohne Probleme, das mit dem Kopierern wird nur ausgeführt, wenn die Datei wirklich nicht existiert und ich erhalte keine Fehlermeldungen, dass entprechende Dateien schon existieren würden.
Ich habe das VBScript in ein Unterverzeichnis kopiert, dort ein Unterverzeichnis namens "FontsToInstall" erstellt und ein paar Fonts reinkopiert, sowohl welche die auf dem System existierten und welche die nicht vorhanden sind.
Das Skript hat wirklich nur die nicht existierenden Schriftartendateien kopiert und für den Rest keine Fehlermeldungen angezeigt, also so wie es eigentlich sein sollte...
Gruss,
Robob.
also bei mir funktioniert der geänderte Code ohne Probleme, das mit dem Kopierern wird nur ausgeführt, wenn die Datei wirklich nicht existiert und ich erhalte keine Fehlermeldungen, dass entprechende Dateien schon existieren würden.
Ich habe das VBScript in ein Unterverzeichnis kopiert, dort ein Unterverzeichnis namens "FontsToInstall" erstellt und ein paar Fonts reinkopiert, sowohl welche die auf dem System existierten und welche die nicht vorhanden sind.
Das Skript hat wirklich nur die nicht existierenden Schriftartendateien kopiert und für den Rest keine Fehlermeldungen angezeigt, also so wie es eigentlich sein sollte...
Gruss,
Robob.
Dim oFSO, oApp, oFolderCopy, oShell
Dim strFontsPath, strScriptPath
Set oFSO = CreateObject("Scripting.FileSystemObject")
Set oShell = CreateObject("WScript.Shell")
Set oApp = CreateObject("Shell.Application")
strScriptPath = WScript.ScriptFullName
strScriptPath = left(strScriptPath,instrrev(strScriptPath,"\"))
strFontsPath = oShell.ExpandEnvironmentStrings("%WINDIR%") & "\Fonts"
Set oFolderCopy = oApp.Namespace(strScriptPath & "FontsToInstall")
For Each oFont In oFolderCopy.Items
IF NOT oFSO.FileExists(strFontsPath & "\" & oFont.Name) Then
oApp.Namespace(strFontsPath).CopyHere oFont
End If
Next
' Cleanup Objects
Set oFolderCopy = Nothing
Set oApp = Nothing
Set oShell = Nothing
Hallo Majce,
nein, ich habe das Skript 3x hintereinander gestartet, beim ersten Mal wurden die nicht vorhandenen Schriftarten in den Windows-Font-Ordner kopiert und es wurden, wie gesagt für die restlichen Schriftarten keine Fehlermeldungen angezeigt und beim 2. und 3. Durchlauf hat das Skript quasi nichts gemacht, es erschienen ebenso keine Fehlermeldungen.
Ich habe das Ganze auf meinem Windows 7 x64 Ultimate-System getestet.
Gruss,
Robert.
nein, ich habe das Skript 3x hintereinander gestartet, beim ersten Mal wurden die nicht vorhandenen Schriftarten in den Windows-Font-Ordner kopiert und es wurden, wie gesagt für die restlichen Schriftarten keine Fehlermeldungen angezeigt und beim 2. und 3. Durchlauf hat das Skript quasi nichts gemacht, es erschienen ebenso keine Fehlermeldungen.
Ich habe das Ganze auf meinem Windows 7 x64 Ultimate-System getestet.
Gruss,
Robert.
Jetzt habe ich ein bisschen weiter experimentiert und bin auch auf eine Schriftart gestossen, bei der das Problem bei mir auch aufgetreten ist, dass auch bei den weiteren Skriptaufrufen ohne neu hinzugekommene Schriftarten immer wieder nach dem Überschreiben der Datei gefragt wurde: Die Schriftart hieß "Victor", bei der der urpsüngliche Dateiname im FontsToInstall-Ordner "victor__.ttf" war und die kopierte Version im Windows-Fonts-Ordner hatte komischerweise plötzlich nur einen Unterstrich, also "victor_.ttf".
Somit handelt es sich im Skript-Aufruf nicht um den gleichen Name und die IF-Anweisung veranlasst eine Kopie der Datei.
Während der Kopie wird aber wohl durch den Windows-Fonts-Ordner der Name der Schriftart ausgelesen, die vom Dateinamen unterschiedlich sein kann, wie man sieht und somit bemängelt, dass es diese Schriftart wohl schon geben würde.
Aber warum die Kopie plötzlich einen Unterstrich beim Dateinamen weglässt ist schon komisch, ich hätte es noch eingesehen, wenn alle Unterstriche entfernt worden wären und der kopierte Dateinamen genau dem in Windows angezeigten Schriftartnamen (ohne Unterstrich) entsprechen würde...
So ist das Ganze jetzt natürlich schwierig...
Gruss,
Robert.
Somit handelt es sich im Skript-Aufruf nicht um den gleichen Name und die IF-Anweisung veranlasst eine Kopie der Datei.
Während der Kopie wird aber wohl durch den Windows-Fonts-Ordner der Name der Schriftart ausgelesen, die vom Dateinamen unterschiedlich sein kann, wie man sieht und somit bemängelt, dass es diese Schriftart wohl schon geben würde.
Aber warum die Kopie plötzlich einen Unterstrich beim Dateinamen weglässt ist schon komisch, ich hätte es noch eingesehen, wenn alle Unterstriche entfernt worden wären und der kopierte Dateinamen genau dem in Windows angezeigten Schriftartnamen (ohne Unterstrich) entsprechen würde...
So ist das Ganze jetzt natürlich schwierig...
Gruss,
Robert.
Hallo Majce,
also auf Netzwerklaufwerken habe ich mit dem Skript keine anderen Probleme als bei lokaler Ausführung (egal ob über gemappten Laufwerksbuchstaben oder UNC-Pfad oder ob Schreib- oder nur Leserechte auf der Freigabe).
Mit den Unterstrichen am Ende von Dateinamen wird bei diesem Kopiervorgang in den Font-Ordner komischerweise immer einer entfernt:
victor__.ttf wird zu victor_.ttf
victor_.ttf wird zu victor.ttf
und bei victor.ttf passt dann auch das Skript wieder, da beide Dateinamen gleich sind...
Dann hoffe ich doch mal, dass Du es noch hinbekommst oder sonst noch jemand eine Idee haben wird.
Gruss,
Robob.
also auf Netzwerklaufwerken habe ich mit dem Skript keine anderen Probleme als bei lokaler Ausführung (egal ob über gemappten Laufwerksbuchstaben oder UNC-Pfad oder ob Schreib- oder nur Leserechte auf der Freigabe).
Mit den Unterstrichen am Ende von Dateinamen wird bei diesem Kopiervorgang in den Font-Ordner komischerweise immer einer entfernt:
victor__.ttf wird zu victor_.ttf
victor_.ttf wird zu victor.ttf
und bei victor.ttf passt dann auch das Skript wieder, da beide Dateinamen gleich sind...
Dann hoffe ich doch mal, dass Du es noch hinbekommst oder sonst noch jemand eine Idee haben wird.
Gruss,
Robob.
Hallo MajceMihajlovic und robob!
Vielleicht geht es mit dem hier vorgestellten Script besser ...
BTW:
ließe sich etwas eleganter so lösen:
Noch eine Anmerkung: In VBS sind Variablendeklarationen ohne
ziemlich witzlos ...
Grüße
bastla
Vielleicht geht es mit dem hier vorgestellten Script besser ...
BTW:
strScriptPath = WScript.ScriptFullName
strScriptPath = left(strScriptPath,instrrev(strScriptPath,"\"))
strScriptPath = Replace(WScript.ScriptFullName, WScript.ScriptName, "")
Option Explicit
Grüße
bastla
Hallo MajceMihajlovic!
Eigentlich ging es darum, eine mit W7-kompatible Methode für die Installation zu finden - mit der beschriebenen Vorgangsweise wird der Kontextmenü-Eintrag "Installieren" (BTW: wäre natürlich an die verwendete Sprache anzupassen) verwendet.
Die Prüfung auf Vorhandensein der Schritart (und dann das Unterlassen eines Installationsversuches) müsste natürlich weiterhin vorweg erfolgen ...
Grüße
bastla
jedoch für 500 Schriften jede einzeln einzutragen
... wäre mir nie eingefallen - da nähme ich dann schon eher eine Schleife ...Eigentlich ging es darum, eine mit W7-kompatible Methode für die Installation zu finden - mit der beschriebenen Vorgangsweise wird der Kontextmenü-Eintrag "Installieren" (BTW: wäre natürlich an die verwendete Sprache anzupassen) verwendet.
Die Prüfung auf Vorhandensein der Schritart (und dann das Unterlassen eines Installationsversuches) müsste natürlich weiterhin vorweg erfolgen ...
Grüße
bastla