Ger*_*ard 9 python string-formatting number-formatting
有没有简洁的格式化数字的方式,有时也可以是一个字符串?
这个数字通常是一个浮点数,但偶尔它也表示为字符串"n/a".
我想用固定数量的小数格式化浮点数,但是如果它不是数字,则打印整个字符串.
例如:
var=3.145623
print("This is {0:.2f}".format(var))
>>>This is 3.14
Run Code Online (Sandbox Code Playgroud)
,但
var = "n/a"
print("This is {0:.2f}".format(var))
>>> File "<stdin>", line 1, in <module>
>>> ValueError: Unknown format code 'f' for object of type 'str'
Run Code Online (Sandbox Code Playgroud)
我对ValueError并不感到惊讶,但想知道是否有简洁的方法,理想情况下没有明确的if语句.
实际上,f格式说明符仅适用于实际float值.你不能避免特殊情况下你的n/a价值.
您可以单独和有条件地格式化浮点数,然后将结果插入到较大的模板中:
var_formatted = format(var, '.2f') if var != 'n/a' else var
print("This is {0:4}".format(var_formatted))
Run Code Online (Sandbox Code Playgroud)
如果你真的厌恶if,你也可以使用异常处理:
try:
var_formatted = format(var, '.2f')
except ValueError:
var_formatted = 'n/a'
print("This is {0:4}".format(var_formatted))
Run Code Online (Sandbox Code Playgroud)
另一种选择是使用__format__方法将值包装在类中:
class OptionalFloat(object):
def __init__(self, value):
self.value = value
def __format__(self, fmt):
try:
return self.value.__format__(fmt)
except ValueError:
return self.value
print("This is {0:.2f}".format(OptionalFloat(var)))
Run Code Online (Sandbox Code Playgroud)
这将需要将类型检测到另一个类方法,保持输出代码更清晰,没有所有那些讨厌的条件或异常处理程序:
>>> var = 3.145623
>>> print("This is {0:.2f}".format(OptionalFloat(var)))
This is 3.15
>>> var = 'n/a'
>>> print("This is {0:.2f}".format(OptionalFloat(var)))
This is n/a
Run Code Online (Sandbox Code Playgroud)
Python 支持非数字 as float('nan'),它可能比代码中的字符串“n/a”更有用。如果您在计算中使用它,它可以处理格式并产生比字符串更合理的结果。
南:
>>> n = float('nan')
>>> n
nan
>>> "{0:.2f}".format(n)
'nan'
>>> n == 3
False
>>> n * 2
nan
>>> n < 5
False
Run Code Online (Sandbox Code Playgroud)
细绳:
>>> n = 'n/a'
>>> "{0:.2f}".format(n)
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
ValueError: Unknown format code 'f' for object of type 'str'
>>> n == 3
False
>>> n * 2
'n/an/a'
>>> n < 5
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
TypeError: unorderable types: str() < int()
Run Code Online (Sandbox Code Playgroud)