python-单击:格式化帮助文本
python-click: formatting help text
这个问题是关于 click 包的:
- 帮助的长文本未按要求显示。
- 我也尝试使用
/b
,但似乎影响不大。
cmd
和 powershell
对于相同的代码都有不同的结果,为什么?
代码:
import click
def command_required_option_from_option(require_name, require_map):
class CommandOptionRequiredClass(click.Command):
def invoke(self, ctx):
require = ctx.params[require_name]
if require not in require_map:
raise click.ClickException(
"Unexpected value for --'{}': {}".format(
require_name, require))
if ctx.params[require_map[require]] is None:
raise click.ClickException(
"With {}={} must specify option --{}".format(
require_name, require, require_map[require]))
super(CommandOptionRequiredClass, self).invoke(ctx)
return CommandOptionRequiredClass
required_options = {
1: 'gs', # generator_string
2: 'nosp', # number_of_sample_points
3: 'nocp', # number_of_center_points
}
@click.command(context_settings=dict(max_content_width=800), cls=command_required_option_from_option('doe', required_options))
@click.option('--input', required=True, type=click.Path(exists=True), metavar='FILE', help="""\b
Path to csv file""" )
@click.option('--doe', required=True, type=int, help="""
\b
Select DOE algorithm:
1 Full factorial
2 2-level fractional factorial
3 Plackett-Burman
4 Sukharev grid
5 Box-Behnken
6 Box-Wilson (Central-composite) with center-faced option
7 Box-Wilson (Central-composite) with center inscribed
8 Box-Wilson (Central-composite) with centser-circumscribed option
9 Latin hypercube (simple)
10 Latin hypercube (space-filling)
11 Random k-means cluster
12 Maximin reconstruction
13 Halton sequence based
14 Uniform random matrix
...
""",)
@click.option( '--gs', required=False, type=str, help="""\b
Generator string for the fractional factorial build""")
@click.option( '--nosp', required=False, type=int, help="""\b
Number of random sample points""")
@click.option( '--nocp', required=False, type=int, help="""\b
Number of center points to be repeated (if more than one):""")
def main(input, doe, gs, nosp, nocp):
click.echo('input: {}'.format(input))
click.echo('doe: {}'.format(doe))
click.echo('generator_string: {}'.format(gs))
click.echo('Num of sample_points: {}'.format(nosp))
click.echo('Num of center_points: {}'.format(nocp))
if __name__ == "__main__":
main()
如果挂钩 click.formatting.wrap_text
,您可以更改 click.Command.get_help
使用的换行器的行为。
代码
因为你已经继承自 click.Command
我们可以构建我们自己的 get_help()
版本来挂接行包装器,如:
def command_required_option_from_option(require_name, require_map):
class CommandOptionRequiredClass(click.Command):
def get_help(self, ctx):
orig_wrap_test = click.formatting.wrap_text
def wrap_text(text, width=78, initial_indent='',
subsequent_indent='',
preserve_paragraphs=False):
return orig_wrap_test(text.replace('\n', '\n\n'), width,
initial_indent=initial_indent,
subsequent_indent=subsequent_indent,
preserve_paragraphs=True
).replace('\n\n', '\n')
click.formatting.wrap_text = wrap_text
return super(CommandOptionRequiredClass, self).get_help(ctx)
return CommandOptionRequiredClass
这是如何工作的?
之所以可行,是因为 click 是一个设计良好的 OO 框架。 @click.command()
装饰器通常实例化一个 click.Command
对象,但允许使用 cls
参数覆盖此行为。因此,在我们自己的 class 中继承 click.Command
并覆盖所需的方法是一件相对容易的事情。
在这种情况下,我们覆盖 click.Command.get_help()。然后在我们的 get_help()
中挂钩 click.formatting.wrap_text()
。在我们的钩子中,我们将 preserve_paragraphs
标志设置为 True
。此外,我们 replace()
所有 \n
都带有 \n\n
,因为这是原始 wrap_text()
期望标记段落的方式。
测试代码:
import click
required_options = {
1: 'gs', # generator_string
2: 'nosp', # number_of_sample_points
3: 'nocp', # number_of_center_points
}
@click.command(context_settings=dict(max_content_width=800),
cls=command_required_option_from_option('doe', required_options))
@click.option('--input', required=True, type=click.Path(exists=True),
metavar='FILE', help="""\b
Path to csv file""" )
@click.option('--doe', required=True, type=int, help="""
Select DOE algorithm:
1 Full factorial
2 2-level fractional factorial
3 Plackett-Burman
4 Sukharev grid
5 Box-Behnken
6 Box-Wilson (Central-composite) with center-faced option
7 Box-Wilson (Central-composite) with center inscribed
8 Box-Wilson (Central-composite) with center-circumscribed option
9 Latin hypercube (simple)
10 Latin hypercube (space-filling)
11 Random k-means cluster
12 Maximin reconstruction
13 Halton sequence based
14 Uniform random matrix
...
""",)
@click.option( '--gs', required=False, type=str, help="""\b
Generator string for the fractional factorial build""")
@click.option( '--nosp', required=False, type=int, help="""\b
Number of random sample points""")
@click.option( '--nocp', required=False, type=int, help="""\b
Number of center points to be repeated (if more than one):""")
def main(input, doe, gs, nosp, nocp):
click.echo('input: {}'.format(input))
click.echo('doe: {}'.format(doe))
click.echo('generator_string: {}'.format(gs))
click.echo('Num of sample_points: {}'.format(nosp))
click.echo('Num of center_points: {}'.format(nocp))
if __name__ == "__main__":
main(['--help'])
结果:
Usage: test.py [OPTIONS]
Options:
--input FILE
Path to csv file [required]
--doe INTEGER Select DOE algorithm:
1 Full factorial
2 2-level fractional factorial
3 Plackett-Burman
4 Sukharev grid
5 Box-Behnken
6 Box-Wilson (Central-composite) with center-faced option
7 Box-Wilson (Central-composite) with center inscribed
8 Box-Wilson (Central-composite) with center-circumscribed
option
9 Latin hypercube (simple)
10 Latin hypercube (space-filling)
11 Random k-means cluster
12 Maximin reconstruction
13 Halton sequence based
14 Uniform random matrix
... [required]
--gs TEXT
Generator string for the fractional factorial build
--nosp INTEGER
Number of random sample points
--nocp INTEGER
Number of center points to be repeated (if more than one):
--help Show this message and exit.
这个问题是关于 click 包的:
- 帮助的长文本未按要求显示。
- 我也尝试使用
/b
,但似乎影响不大。 cmd
和powershell
对于相同的代码都有不同的结果,为什么?
代码:
import click
def command_required_option_from_option(require_name, require_map):
class CommandOptionRequiredClass(click.Command):
def invoke(self, ctx):
require = ctx.params[require_name]
if require not in require_map:
raise click.ClickException(
"Unexpected value for --'{}': {}".format(
require_name, require))
if ctx.params[require_map[require]] is None:
raise click.ClickException(
"With {}={} must specify option --{}".format(
require_name, require, require_map[require]))
super(CommandOptionRequiredClass, self).invoke(ctx)
return CommandOptionRequiredClass
required_options = {
1: 'gs', # generator_string
2: 'nosp', # number_of_sample_points
3: 'nocp', # number_of_center_points
}
@click.command(context_settings=dict(max_content_width=800), cls=command_required_option_from_option('doe', required_options))
@click.option('--input', required=True, type=click.Path(exists=True), metavar='FILE', help="""\b
Path to csv file""" )
@click.option('--doe', required=True, type=int, help="""
\b
Select DOE algorithm:
1 Full factorial
2 2-level fractional factorial
3 Plackett-Burman
4 Sukharev grid
5 Box-Behnken
6 Box-Wilson (Central-composite) with center-faced option
7 Box-Wilson (Central-composite) with center inscribed
8 Box-Wilson (Central-composite) with centser-circumscribed option
9 Latin hypercube (simple)
10 Latin hypercube (space-filling)
11 Random k-means cluster
12 Maximin reconstruction
13 Halton sequence based
14 Uniform random matrix
...
""",)
@click.option( '--gs', required=False, type=str, help="""\b
Generator string for the fractional factorial build""")
@click.option( '--nosp', required=False, type=int, help="""\b
Number of random sample points""")
@click.option( '--nocp', required=False, type=int, help="""\b
Number of center points to be repeated (if more than one):""")
def main(input, doe, gs, nosp, nocp):
click.echo('input: {}'.format(input))
click.echo('doe: {}'.format(doe))
click.echo('generator_string: {}'.format(gs))
click.echo('Num of sample_points: {}'.format(nosp))
click.echo('Num of center_points: {}'.format(nocp))
if __name__ == "__main__":
main()
如果挂钩 click.formatting.wrap_text
,您可以更改 click.Command.get_help
使用的换行器的行为。
代码
因为你已经继承自 click.Command
我们可以构建我们自己的 get_help()
版本来挂接行包装器,如:
def command_required_option_from_option(require_name, require_map):
class CommandOptionRequiredClass(click.Command):
def get_help(self, ctx):
orig_wrap_test = click.formatting.wrap_text
def wrap_text(text, width=78, initial_indent='',
subsequent_indent='',
preserve_paragraphs=False):
return orig_wrap_test(text.replace('\n', '\n\n'), width,
initial_indent=initial_indent,
subsequent_indent=subsequent_indent,
preserve_paragraphs=True
).replace('\n\n', '\n')
click.formatting.wrap_text = wrap_text
return super(CommandOptionRequiredClass, self).get_help(ctx)
return CommandOptionRequiredClass
这是如何工作的?
之所以可行,是因为 click 是一个设计良好的 OO 框架。 @click.command()
装饰器通常实例化一个 click.Command
对象,但允许使用 cls
参数覆盖此行为。因此,在我们自己的 class 中继承 click.Command
并覆盖所需的方法是一件相对容易的事情。
在这种情况下,我们覆盖 click.Command.get_help()。然后在我们的 get_help()
中挂钩 click.formatting.wrap_text()
。在我们的钩子中,我们将 preserve_paragraphs
标志设置为 True
。此外,我们 replace()
所有 \n
都带有 \n\n
,因为这是原始 wrap_text()
期望标记段落的方式。
测试代码:
import click
required_options = {
1: 'gs', # generator_string
2: 'nosp', # number_of_sample_points
3: 'nocp', # number_of_center_points
}
@click.command(context_settings=dict(max_content_width=800),
cls=command_required_option_from_option('doe', required_options))
@click.option('--input', required=True, type=click.Path(exists=True),
metavar='FILE', help="""\b
Path to csv file""" )
@click.option('--doe', required=True, type=int, help="""
Select DOE algorithm:
1 Full factorial
2 2-level fractional factorial
3 Plackett-Burman
4 Sukharev grid
5 Box-Behnken
6 Box-Wilson (Central-composite) with center-faced option
7 Box-Wilson (Central-composite) with center inscribed
8 Box-Wilson (Central-composite) with center-circumscribed option
9 Latin hypercube (simple)
10 Latin hypercube (space-filling)
11 Random k-means cluster
12 Maximin reconstruction
13 Halton sequence based
14 Uniform random matrix
...
""",)
@click.option( '--gs', required=False, type=str, help="""\b
Generator string for the fractional factorial build""")
@click.option( '--nosp', required=False, type=int, help="""\b
Number of random sample points""")
@click.option( '--nocp', required=False, type=int, help="""\b
Number of center points to be repeated (if more than one):""")
def main(input, doe, gs, nosp, nocp):
click.echo('input: {}'.format(input))
click.echo('doe: {}'.format(doe))
click.echo('generator_string: {}'.format(gs))
click.echo('Num of sample_points: {}'.format(nosp))
click.echo('Num of center_points: {}'.format(nocp))
if __name__ == "__main__":
main(['--help'])
结果:
Usage: test.py [OPTIONS]
Options:
--input FILE
Path to csv file [required]
--doe INTEGER Select DOE algorithm:
1 Full factorial
2 2-level fractional factorial
3 Plackett-Burman
4 Sukharev grid
5 Box-Behnken
6 Box-Wilson (Central-composite) with center-faced option
7 Box-Wilson (Central-composite) with center inscribed
8 Box-Wilson (Central-composite) with center-circumscribed
option
9 Latin hypercube (simple)
10 Latin hypercube (space-filling)
11 Random k-means cluster
12 Maximin reconstruction
13 Halton sequence based
14 Uniform random matrix
... [required]
--gs TEXT
Generator string for the fractional factorial build
--nosp INTEGER
Number of random sample points
--nocp INTEGER
Number of center points to be repeated (if more than one):
--help Show this message and exit.