有没有一个简单的方法用Python f字符串来固定小数点后的位数?(特别是f字符串,而不是其他字符串格式选项,如。格式或%)
例如,假设我想在小数点后显示2位数字。
我该怎么做?这么说吧
a = 10.1234
加入罗布ᵩ's回答:如果你想打印相当大的数字,使用千个分隔符会很有帮助(注意逗号)。
>>> f'{a*1000:,.2f}'
'10,123.40'
当涉及到float
数字时,可以使用格式说明符:
f'{value:{width}.{precision}}'
哪里:
value
是任何计算结果为数字的表达式您缺少的是十进制值的类型说明符。在这个链接中,您可以找到浮点和十进制的可用表示类型。
这里有一些示例,使用f
(固定点)表示类型:
# notice that it adds spaces to reach the number of characters specified by width
In [1]: f'{1 + 3 * 1.5:10.3f}'
Out[1]: ' 5.500'
# notice that it uses more characters than the ones specified in width
In [2]: f'{3000 + 3 ** (1 / 2):2.1f}'
Out[2]: '3001.7'
In [3]: f'{1.2345 + 4 ** (1 / 2):9.6f}'
Out[3]: ' 3.234500'
# omitting width but providing precision will use the required characters to display the number with the the specified decimal places
In [4]: f'{1.2345 + 3 * 2:.3f}'
Out[4]: '7.234'
# not specifying the format will display the number with as many digits as Python calculates
In [5]: f'{1.2345 + 3 * 0.5}'
Out[5]: '2.7344999999999997'
在格式表达式中包含类型说明符:
>>> a = 10.1234
>>> f'{a:.2f}'
'10.12'
问题内容: Python f字符串是否有一种简单的方法来固定小数点后的位数?(特别是f字符串,而不是其他字符串格式设置选项,例如.format或%) 例如,假设我要在小数点后显示2位数字。 我怎么做?比方说 问题答案: 在格式表达式中包括类型说明符:
问题内容: 我在ex中有整数。16,我正在尝试将此数字转换为十六进制数字。我试图通过使用十六进制函数来实现此目的,但是每当您向十六进制函数提供整数时,它都会返回十六进制数字的字符串表示形式, 有人可以告诉我如何将字符串格式的十六进制数字转换为简单的十六进制数字。 谢谢!! 问题答案:
问题内容: 我将数据存储在字节数组中。如何将这些数据转换为十六进制字符串? 我的字节数组示例: 问题答案: 使用: 或使用 注意: 在format语句中,表示在必要时最多填充2个前导s。这很重要,因为它将被格式化为而不是 或与配合使用: 这是Python 3.6.1中上述方法的基准: 结果: 使用的方法的确提供了其他格式选项,例如用空格,逗号,大写字母/等分隔数字,但是会影响性能。
我试图组成一个格式化的字符串,应该看起来像这样: 一瓶伏特加要x.yz卢布。 其中x.yz是四舍五入为2个小数点的任意双精度值。 为了实现这一点,我使用字符串插值和printf语法: 不幸的是,在一台使用俄语语言环境的机器上,上面的代码片段产生的结果与我想要实现的结果略有不同: str:String=一瓶伏特加要2.56卢布。 这是可以理解的(f interpolator使用的Java格式化程序应
问题内容: 我写了一些代码将十六进制显示字符串转换为十进制整数。但是,当输入类似100a或625b(带有字母的东西)时,我得到了这样的错误: java.lang.NumberFormatException:对于输入字符串:java.lang.Integer.parseInt(未知源)处的java.lang.NumberFormatException.forInputString(未知源)处为“ 1
我正在写一个Rust程序,读取I2C总线并保存数据。当我读取I2C总线时,我会得到十六进制值,比如,,等等。 现在,我只能将其作为字符串处理并按原样保存。有没有办法把它解析成一个整数?它有内置的功能吗?