ahe
Goto Top

Auswertung bzw. Verwendung von Übergabeparametern.

Problem:
Auswertung von Übergabeparametern.
(OS = Windows XP)

Ein Programm benötigt beim Start einige Parameter, die mit Hilfe eine Batch auf Vorhandensein und Gültigkeit geprüft werden müssen.

back-to-topAuswertung bzw. Verwendung von Übergabeparametern. (OS = Windows XP)


Ein Programm benötigt beim Start einige Parameter, die mit Hilfe eine Batch auf Vorhandensein und Gültigkeit geprüft werden müssen.

MeineProgramm.exe -Parameter1 -Parameter2 -OptionalerParameter3

Werte der Parameter:

Parameter1: AUTO oder BUS oder ZUG -> Parametergruppe: Fahrzeug
Parameter2: BLOND oder ROTHAARIG -> Parametergruppe: Haarfarbe
OptionalerParameter3: ASSISTENTIN -> Opt. Parameter: Biber's Wunsch face-smile

Jeder Parameter kann/darf nur einen Wert haben, die Parameter 1 und 2 müssen gefüllt sein, der Parameter 3 ist optional.

Gültige Aufrufe wären:

MeinProgramm.exe -AUTO -ROTHAARIG -ASSISTENTIN
MeinProgramm.exe -BUS -BLOND
MeinProgramm.exe -ZUG -BLOND -ASSISTENTIN
. . .

Ungültige Aufrufe wären:
MeinProgramm.exe -AUTO -BUS -ASSISTENTIN
MeinProgramm.exe -ZUG -BLOND -ROTHAARIG
MeinProgramm.exe -BLOND -ROTHAARIG -ASSISTENTIN

back-to-topAufgabe


Die zu erstellende Batch soll verhindern, dass ungültige Parameter beim Aufruf der EXE verwendet werden, es sollen daher
  • auch vergessene Minuszeichen "-" erkannt werden
  • die Reihenfolge der angegebenen Parameter soll so sortiert werden, dass sie für die EXE gültig sind, z. B.:
            • StartMeinProgramm.cmd -BLOND -ASSISTENTIN -ZUG -> führt zu dem Aufruf der EXE: MeinProgramm.exe -ZUG -BLOND -ASSISTENTIN
            • StartMeinProgramm.cmd -ROTHAARIG -AUTO -> führt zu dem Aufruf der EXE: MeinProgramm.exe -AUTO -ROTHAARIG
  • die Anzahl der Parameter geprüft werden, da mehr als drei Parameter falsch sind
  • jeder Parameter höchstens einmal vorkommen
  • die ersten beiden Parameter müssen gefüllt sein

back-to-topErster Schritt: Ermittlung der Parameteranzahl


@echo off & setlocal enabledelayedexpansion
set /a mycount=0

rem Get the number of parameters
@for %%a in (%*) do (
	set /a mycount=!mycount! + 1
)
echo Number of Parameters: %mycount%

if [%mycount%] GTR [3] GOTO :COUNTERR

GOTO :END

:COUNTERR
Echo Too many parameters ...
GOTO :END

:END

back-to-topZweiter Schritt: Prüfen, ob vor jedem Parameter auch ein Minus sitzt.


@echo off & setlocal enabledelayedexpansion
set /a mycount=0
set /a myminuscount=0

rem Get the number of parameters
@for %%a in (%*) do (
	set /a mycount=!mycount! + 1
	set minuscheck=%%a
	if ["!minuscheck:~0,1!"] == ["-"] set /a myminuscount=!myminuscount! + 1  
)
echo Number of Parameters: %mycount%
echo Number of Minus: %myminuscount%


if [%mycount%] GTR [3] GOTO :COUNTERR
if [%myminuscount%] NEQ [%mycount%] GOTO :MINUSERR
goto :END

:COUNTERR
Echo Too many parameters ...
GOTO :END

:MINUSERR
Echo Forgotton Minus "-" ...  
GOTO :END

:END

Allerdings wird ein einzelnes Minus jetzt auch als Parameter gewertet und bringt ein positives Ergebnis:
StartMeinProgramm.cmd -ROTHAARIG -AUTO -

Number of Parameters: 3
Number of Minus: 3

Dies kann man verhindern, in dem man in der for-Schleife die If-Abfrage folgendermaßen anpasst:
	if ["!minuscheck:~0,1!"] == ["-"] (  
		if not ["!minuscheck:~1,2!"] == [""] set /a myminuscount=!myminuscount! + 1)  

Danach erscheint dann die folgende Ausgabe:
StartMeinProgramm.cmd -ROTHAARIG -AUTO -

Number of Parameters: 3
Number of Minus: 2
Forgotton Minus "-" ...  


back-to-topDritter Schritt: Prüfen, ob für jeden der ersten beiden Parameter auch nur ein Wert gesetzt wurde.


A: Ist jede Gruppe in der Parameterliste vertreten?
B: Ist aus jeder Gruppe maximal ein Vertreter vorhanden?

Hinzufügen der folgenden Zeilen setzt jeweils einen Zähler hoch
set "FAHRZEUGE=AUTO BUS ZUG"  
set "HAARFARBE=BLOND ROTHAARIG"  
set "OPTIONAL=ASSISTENTIN"  

set /a FAHRZEUGE_Count=0
set /a HAARFARBE_Count=0
...
for %%i in (%FAHRZEUGE%) do (
	for %%m in (%*) do (
		rem To compare the string, add the minus as first letter for %%i
		if /i "-%%i"=="%%m" (set /a FAHRZEUGE_Count=!FAHRZEUGE_Count! + 1)  
	)
)
for %%i in (%HAARFARBE%) do (
	for %%m in (%*) do (
		rem To compare the string, add the minus as first letter for %%i
		echo m: %%m; i: %%i
		if /i "-%%i"=="%%m" (set /a HAARFARBE_Count=!HAARFARBE_Count! + 1)  
	)
)
if %FAHRZEUGE_Count% LSS 1 (set msg=No parameter for Fahrzeuge & GOTO :PARAMCOUNTERR) 
if %HAARFARBE_Count% LSS 1 (set msg=No parameter for Haarfarbe & GOTO :PARAMCOUNTERR)
if %FAHRZEUGE_Count% GTR 1 (set msg=To many parameters for Fahrzeuge & GOTO :PARAMCOUNTERR) 
if %HAARFARBE_Count% GTR 1 (set msg=To many parameters for Haarfarbe & GOTO :PARAMCOUNTERR)
...
:PARAMCOUNTERR
ECHO %msg%
GOTO :END

Jetzt sind zwar alle Anzahlen bestimmt und das Vorhandensein verifiziert, allerdings welche gültigen Werte eingegeben wurden ist noch nicht bekannt.

Durch Einfügen jeweils einer weiteren Zeile in der obigen If-Abfrage wird das dann auch gelöst:
...
		if /i "-%%i"=="%%m" (  
			set /a FAHRZEUGE_Count=!FAHRZEUGE_Count! + 1
			set parmFahrzeug=%%m)
...
		if /i "-%%i"=="%%m" (  
			set /a HAARFARBE_Count=!HAARFARBE_Count! + 1
			set parmHaarfarbe=%%m)
...
echo Fahrzeug: %parmFahrzeug%; Haarfarbe: %parmHaarfarbe%

Doch da war noch was, der optionale dritte Parameter...
for %%m in (%*) do (
	rem To compare the string, add the minus as first letter for %%i
	if /i "-%OPTIONAL%"=="%%m" (set parmOptional=%%m)  
)
echo Fahrzeug: %parmFahrzeug%; Haarfarbe: %parmHaarfarbe%; Optional: %parmOptional%


back-to-topVierter Schritt: Zusammenfügen der Kommandozeile.


start /wait MeinProgramm.exe %parmFahrzeug% %parmFahrzeug% %parmOptional%

Tja, eigentlich wollte ich ja eine Frage stellen, nun, so wie es aussieht, funktioniert es jetzt, aber es gibt sicherlich noch etwas Optimierungspotential...

mfg
Axel


back-to-topDer vollständige Code:

@echo off & setlocal enabledelayedexpansion
set /a mycount=0
set /a myminuscount=0
set msg=

set "FAHRZEUGE=AUTO BUS ZUG"  
set "HAARFARBE=BLOND ROTHAARIG"  
set "OPTIONAL=ASSISTENTIN"  

set /a FAHRZEUGE_Count=0
set /a HAARFARBE_Count=0

rem Get the number of parameters
for %%a in (%*) do (
	set /a mycount=!mycount! + 1
	set minuscheck=%%a
	if ["!minuscheck:~0,1!"] == ["-"] (  
		if not ["!minuscheck:~1,2!"] == [""] set /a myminuscount=!myminuscount! + 1)  
)
echo Number of Parameters: %mycount%
echo Number of Minus: %myminuscount%

if [%mycount%] GTR [3] GOTO :COUNTERR
if [%myminuscount%] NEQ [%mycount%] GOTO :MINUSERR

for %%i in (%FAHRZEUGE%) do (
	for %%m in (%*) do (
		rem To compare the string, add the minus as first letter for %%i
		if /i "-%%i"=="%%m" (  
			set /a FAHRZEUGE_Count=!FAHRZEUGE_Count! + 1
			set parmFahrzeug=%%m)
	)
)
for %%i in (%HAARFARBE%) do (
	for %%m in (%*) do (
		rem To compare the string, add the minus as first letter for %%i
		if /i "-%%i"=="%%m" (  
			set /a HAARFARBE_Count=!HAARFARBE_Count! + 1
			set parmHaarfarbe=%%m)
	)
)

if %FAHRZEUGE_Count% LSS 1 (set msg=No parameter for Fahrzeuge & GOTO :PARAMCOUNTERR) 
if %HAARFARBE_Count% LSS 1 (set msg=No parameter for Haarfarbe & GOTO :PARAMCOUNTERR)
if %FAHRZEUGE_Count% GTR 1 (set msg=To many parameters for Fahrzeuge & GOTO :PARAMCOUNTERR) 
if %HAARFARBE_Count% GTR 1 (set msg=To many parameters for Haarfarbe & GOTO :PARAMCOUNTERR)

for %%m in (%*) do (
	rem To compare the string, add the minus as first letter for %%i
	if /i "-%OPTIONAL%"=="%%m" (set parmOptional=%%m)  
)

echo Fahrzeug: %parmFahrzeug%; Haarfarbe: %parmHaarfarbe%; Optional: %parmOptional%
GOTO :END

:COUNTERR
Echo Too many parameters ...
GOTO :END

:MINUSERR
Echo Forgotton Minus "-" ...  
GOTO :END

:PARAMCOUNTERR
ECHO %msg%
GOTO :END

:END

Content-ID: 105396

Url: https://administrator.de/contentid/105396

Ausgedruckt am: 25.11.2024 um 05:11 Uhr

bastla
bastla 07.01.2009 um 15:12:17 Uhr
Goto Top
Hallo ahe!

Hab' zwar nur kurz drübergeschaut - sieht aber für mich sehr gut aus ... face-smile

2 Kleinigkeiten:
- Falls die Varaiable %allparameters% überhaupt benötigt wird, sollte als Ersatz der Zeilen 27 und 28
set "allparameters=%*"
genügen.

- Ich tendiere eher zur Schreibweise
set /a mycount+=1
erspart - zumindest dafür - die "delayedExpansion", ist hier aber eher Geschmackssache.

Grüße
bastla
ahe
ahe 07.01.2009 um 15:26:10 Uhr
Goto Top
Hallo bastla,

"allparameters" wird tatsächlich nicht gebraucht, war beim Entstehen wichtig, doch dann nicht mehr... (ist oben jetzt gelöscht!)

Nun die kurze Schreibweise des Hochzählens kam mir dann auch später in den Sinn, nur hatte ich es da bereits geschrieben... face-smile

mfg
Axel
Biber
Biber 07.01.2009 um 16:13:35 Uhr
Goto Top
Moin ahe,

also hömma - Du kannst Doch hier nicht einfach ein Tutorial als normalen Beitrag ins Forum stellen. face-wink

Ich habe es für Dich mal umgestuft von "Beitrag" auf "Anleitung".

Heute morgen habe ich in einem anderen Beitrag ein Negativ-Beispiel für unleserlichen, unwartbaren und nicht nachvollziehbaren Code angemeckert.
Nun möchte nun auch das Lob für einen sauber hergeleiteten Skriptschnipsel nicht unter den Tisch falllen lassen..

Vielen Dank für Deine Mühe und Sorgfalt
Biber
ahe
ahe 07.01.2009 um 16:19:21 Uhr
Goto Top
Danke für die Blumen,

nachdem ich meine erste, nicht funktionierende Version hatte und nicht mehr durchblickte, habe ich mir erst einmal aufgeschrieben, was ich machen wollte und so ergab sich das Ganze fast von selbst. Außerdem habe ich dabei auch an Dich gedacht face-smile (s. a. der optionale Parameter...)

mfg
Axel
bastla
bastla 07.01.2009 um 17:02:21 Uhr
Goto Top
@Biber
also hömma - Du kannst Doch hier nicht einfach ein Tutorial als normalen Beitrag ins Forum stellen. face-wink
Annähernd face-wink so hatte ich es auch schon in meinem obigen Kommentar formuliert, mir aber dann gedacht: "Das ist Chefsache." und den Teil wieder rausgeschmissen ...

Grüße
bastla