Boolesche Werte mit argparse analysieren
Bei der Verwendung von argparse zum Parsen boolescher Befehlszeilenargumente kommt es häufig zu Szenarios, in denen das gewünschte Verhalten unterschiedlich ist von der tatsächlichen Ausgabe. Dies tritt auf, wenn Argumente als „--foo True“ oder „--foo False“ angegeben werden.
Um dieses Problem zu beheben, ist es wichtig, tiefer in den Code einzutauchen:
<code class="python">import argparse parser = argparse.ArgumentParser(description="My parser") parser.add_argument("--my_bool", type=bool) cmd_line = ["--my_bool", "False"] parsed_args = parser.parse(cmd_line)</code>
Überraschenderweise wird parsed_args.my_bool trotz der Angabe von „False“ als Argument als „True“ ausgewertet. Diese Anomalie bleibt auch bestehen, wenn cmd_line in ["--my_bool", ""] geändert wird, was logischerweise als Falsch ausgewertet werden sollte.
Lösung
Um diese Herausforderung zu meistern Um boolesche Werte präzise zu analysieren, besteht ein empfohlener Ansatz darin, den konventionelleren Stil zu übernehmen:
command --feature
und
command --no-feature
argparse unterstützt mühelos dieses Format:
Python 3.9 und höher:
<code class="python">parser.add_argument('--feature', action=argparse.BooleanOptionalAction)</code>
Python unter 3.9:
<code class="python">parser.add_argument('--feature', action='store_true') parser.add_argument('--no-feature', dest='feature', action='store_false') parser.set_defaults(feature=True)</code>
Alternativ, wenn „--arg Das obige ist der detaillierte Inhalt vonWie kann man boolesche Werte mit „argparse' genau analysieren?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!<code class="python">def t_or_f(arg):
ua = str(arg).upper()
if 'TRUE'.startswith(ua):
return True
elif 'FALSE'.startswith(ua):
return False
else:
pass #error condition maybe?</code>