我有一个函数接受浮点参数(通常是整数或有一个有效数字的小数),我需要在一个有两位小数的字符串中输出值(5→5.00,5.5→5.50等)。如何在Python中做到这一点?


当前回答

使用python字符串格式化。

>>> "%0.2f" % 3
'3.00'

其他回答

Python 3

print(f"{number:.2f}")

一种更简短的格式化方法。

如果你真的想改变数字本身,而不是仅仅以不同的方式显示它,请使用format()

格式为小数点后2位:

format(value, '.2f')

例子:

>>> format(5.00000, '.2f')
'5.00'

如果你想在调用输入时得到一个小数点后两位有限制的浮点值,

看看这个~

a = eval(format(float(input()), '.2f'))   # if u feed 3.1415 for 'a'.
print(a)                                  # output 3.14 will be printed.

经过一些积累,我遇到了这个问题。所以我学到的是把你想要的数字相乘,最后除以相同的数字。所以它应该是这样的:(100(x+y))/100 = x+y如果你的数字是0.01 20.1 3 05。 如果您的数字是未知的,您可以使用number * (len(number)-1)**10。

f-string格式:

这是Python 3.6中的新功能——字符串像往常一样放在引号中,前面加上f'…以同样的方式你会……对于一个原始字符串。然后你在字符串中放入你想要放入的任何东西,变量,数字,括号内的一些字符串文本,在该文本中带有{variable}或{number}——Python的计算方法与以前的字符串格式化方法一样,只是这个方法可读性更高。

>>> foobar = 3.141592
>>> print(f'My number is {foobar:.2f} - look at the nice rounding!')

My number is 3.14 - look at the nice rounding!

在这个示例中,您可以看到我们使用与前面的字符串格式化方法类似的方式对小数进行格式化。

foobar可以是一个数字,变量,甚至是一个表达式,例如f'{3*my_func(3.14):02f}'。

展望未来,在新的代码中,我更喜欢f-字符串而不是普通的%s或str.format()方法,因为f-字符串可以更易于阅读,而且通常更快。