格式值,可以是python 3中的数字和/或字符串

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语句.

Mar*_*ers 6

实际上,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)


tde*_*ney 4

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)