一个快速的不费吹灰之力:
some_float = 1234.5678
print '%02d' % some_float # 1234
some_float = 1234.5678
print '{WHAT?}'.format(some_float) # I want 1234 here too
注意:{:.0f}
不是一个选项,因为它会四舍五入(1235
在本例中返回)。
format(..., int(some_float))
正是我试图避免的事情,请不要建议。
值得一提的是如何使用原始格式字符串呈现浮点数的内置行为。如果您事先知道小数部分相对于 0.5 的位置,则可以利用您最初尝试但发现它因四舍五入的副作用而不足的格式字符串"{:0.0f}"
。查看以下示例...
>>> "{:0.0f}".format(1.999)
'2'
>>> "{:0.0f}".format(1.53)
'2'
>>> "{:0.0f}".format(1.500)
'2'
>>> "{:0.0f}".format(1.33)
'1'
>>> "{:0.0f}".format(0.501)
'1'
>>> "{:0.0f}".format(0.5)
'0'
>>> "{:0.0f}".format(0.1)
'0'
>>> "{:0.0f}".format(0.001)
'0'
如您所见,幕后有舍入行为。在我有一个将整数转换为浮点数的数据库的情况下,我知道我正在处理一个非小数部分,并且只想在 html 模板中呈现浮点数的 int 部分作为解决方法。当然,如果您事先不知道小数部分,则需要先对浮点数执行某种截断操作。
可以通过扩展类string.Formatter来扩展标准字符串格式化语言:
class MyFormatter(Formatter):
def format_field(self, value, format_spec):
if format_spec == 't': # Truncate and render as int
return str(int(value))
return super(MyFormatter, self).format_field(value, format_spec)
MyFormatter().format("{0} {1:t}", "Hello", 4.567) # returns "Hello 4"
这有效:
from math import trunc
some_float = 1234.5678
print '{:d}'.format(trunc(some_float))
=> 1234
或者就这样做,就此而言:
print trunc(some_float)
=> 1234
我认为这是一个可以接受的答案,它避免了转换为int
. 请注意,在此代码段中:正在发生'%02d' % some_float
隐式转换int
,您无法避免以所需格式打印的某种转换。
这也可以:
some_float = 1234.5678
f = lambda x: str(x)[:str(x).find('.')]
print '{}'.format(f(some_float))
=> 1234
在进行 %timeit 测试后,它看起来比 trunc 方法快一点。