我有一个如下字符串:
a = "This is {} code {}"
在我的代码的后半部分,我将使用提供给以下函数的args格式化字符串:
def format_string(str, *args):
fmt_str = str.format(*args)
print fmt_str
...
我的问题是,如果提供给函数format_string
的args数量小于或大于所需数量,我会得到一个异常。
相反,如果args较小,我希望它打印空{},如果args超过需要,那么我希望忽略额外的args。
我试图这样做有几种方法,但无法避免异常。有人可以帮忙吗?
更新:我能够根据这篇文章中提供的答案解决这个问题: Leaving values blank if not passed in str.format
这是我的实施:
class BlankFormatter(Formatter):
def __init__(self, default=''):
self.default = default
def get_value(self, key, args, kwargs):
if isinstance(key, (int, long)):
try:
return args[key]
except IndexError:
return ""
else:
return kwargs[key]
必须按如下方式修改字符串才能使用上面的BlankFormatter:
a = "This is {0} code {1}"
在我的format_string函数中,我使用BlankFormatter格式化字符串:
def format_string(str, *args):
fmt = BlankFormatter()
fmt_str = fmt.format(str,*args)
print fmt_str
...
答案 0 :(得分:1)
有几种不同的方法可以做到这一点,其中一些方法或多或少具有灵活性。也许这样的事情对你有用:
from __future__ import print_function
def transform_format_args(*args, **kwargs):
num_args = kwargs['num_args'] # required
filler = kwargs.get('filler', '') # optional; defaults to ''
if len(args) < num_args: # If there aren't enough args
args += (filler,) * (num_args - len(args)) # Add filler args
elif len(args) > num_args: # If there are too many args
args = args[:num_args] # Remove extra args
return args
args1 = transform_format_args('cool', num_args=2)
print("This is {} code {}.".format(*args1)) # This is cool code .
args2 = transform_format_args('bird', 'worm', 'fish', num_args=2)
print("The {} ate the {}.".format(*args2)) # The bird ate the worm.
args3 = transform_format_args(num_args=3, filler='thing')
print("The {} stopped the {} with the {}.".format(*args3))
# The thing stopped the thing with the thing.
num_args
是您想要的args
的数量,而不是您传入的数量。filler
是在args
不足时使用的内容。< / p>
答案 1 :(得分:0)
def formatter(input, *args):
format_count = input.count("{}")
args = list(args) + ["{}"] * (format_count - len(args))
print input.format(*args[:format_count])
formatter("{} {} {}", "1", "2")
formatter("{} {} {}", "1", "2", "3")
formatter("{} {} {}", "1", "2", "3", "4")
1 2 {}
1 2 3
1 2 3