30.2 Ein weiteres Beispiel 

Im vorangegangenen Abschnitt haben wir Ihnen ein Minimalbeispiel für die Verwendung von argparse gezeigt. Dieses Beispielprogramm wird in diesem Abschnitt erweitert, um weitere Möglichkeiten vorzustellen, die das Modul argparse bietet. Hier sehen Sie zunächst den Quellcode des veränderten Beispielprogramms:
from argparse import ArgumentParser
parser = ArgumentParser(description = "Ein Taschenrechner")
parser.add_argument("-o", "--operation", dest="operation",
default="plus", help="Rechenoperation")
parser.add_argument("operanden", metavar="Operand", type=float,
nargs="+", help="Operanden")
parser.add_argument("-i", "--integer", dest="type",
action="store_const", const=int, default=float,
help="Ganzzahlige Berechnung")
args = parser.parse_args()
calc = {
"plus" : lambda a, b: a + b,
"minus" : lambda a, b: a - b,
"mal" : lambda a, b: a * b,
"geteilt" : lambda a, b: a / b
}
op = args.operation
if op in calc:
ergebnis = args.type(args.operanden[0])
for z in args.operanden[1:]:
ergebnis = calc[op](ergebnis, args.type(z))
print("Ergebnis:", ergebnis)
else:
parser.error("{} ist keine gültige Operation".format(op))
Zunächst wird beim Hinzufügen neuer Argumente konsequent der Schlüsselwortparameter help übergeben. Hier kann eine Beschreibung des Arguments in Form eines Strings angegeben werden, die das Modul argparse dazu verwendet, eine dynamisch generierte Hilfeseite anzubieten. Diese Hilfeseite wird angezeigt, wenn das Programm mit der Option -h bzw. --help aufgerufen wird. Für das oben dargestellte Beispiel sieht die Hilfeseite folgendermaßen aus:
usage: taschenrechner2.py [-h] [-o OPERATION] [-i] Operand [Operand ...]
Ein Taschenrechner
positional arguments:
Operand Operanden
optional arguments:
-h, --help show this help message and exit
-o OPERATION, --operation OPERATION
Rechenoperation
-i, --integer Ganzzahlige Berechnung
Anhand der Hilfeseite wird eine weitere Änderung im Beispielprogramm ersichtlich: Es werden nicht mehr zwei Argumente op1 und op2 erwartet, sondern eine Liste von beliebig vielen Argumenten (aber mindestens einem Argument). Dies erreichen Sie, indem Sie beim add_argument-Aufruf den Parameter nargs auf den Wert "+" setzen. Zusätzlich wird mittels metavar ein Name festgelegt, unter dem das Argument auf der Hilfeseite erscheint. Die Berechnung des Ergebnisses aus der Operandenliste args.operanden erfolgt von links nach rechts, was insbesondere bei den nicht assoziativen Operatoren - und / wichtig ist. Der beispielhafte Aufruf
python taschenrechner2.py -o minus 1 2 3
führt die Berechnung 1 - 2 - 3 durch und kommt zu dem Ergebnis -4.