我正在尝试为我的Python程序制作一个详细的标志。 目前,我正在这样做:
import click
#global variable
verboseFlag = False
#parse arguments
@click.command()
@click.option('--verbose', '-v', is_flag=True, help="Print more output.")
def log(verbose):
global verboseFlag
verboseFlag = True
def main():
log()
if verboseFlag:
print("Verbose on!")
if __name__ == "__main__":
main()
它永远不会打印“ Verbose on!”。即使设置了“ -v”参数。我的想法是log函数需要一个参数,但是我应该给它什么呢?另外,有没有办法检查是否在没有全局变量的情况下启用了详细标记?
答案 0 :(得分:10)
因此,单击不仅仅是命令行解析器。它还分派和处理命令。因此,在您的示例中,0.5
函数永远不会返回到log()
。该框架的目的是修饰后的函数main()
将完成所需的工作。
log()
import click
@click.command()
@click.option('--verbose', '-v', is_flag=True, help="Print more output.")
def log(verbose):
click.echo("Verbose {}!".format('on' if verbose else 'off'))
def main(*args):
log(*args)
if __name__ == "__main__":
commands = (
'--verbose',
'-v',
'',
'--help',
)
import sys, time
time.sleep(1)
print('Click Version: {}'.format(click.__version__))
print('Python Version: {}'.format(sys.version))
for cmd in commands:
try:
time.sleep(0.1)
print('-----------')
print('> ' + cmd)
time.sleep(0.1)
main(cmd.split())
except BaseException as exc:
if str(exc) != '0' and \
not isinstance(exc, (click.ClickException, SystemExit)):
raise
答案 1 :(得分:2)
以上答案很有帮助,但这就是我最终使用的答案。我想分享一下,因为有这么多人在看这个问题:
@click.command()
@click.option('--verbose', '-v', is_flag=True, help="Print more output.")
def main(verbose):
if verbose:
# do something
if __name__ == "__main__":
# pylint: disable=no-value-for-parameter
main()