问题
你需要将数字格式化后输出,并控制数字的位数、对齐、千位分隔符和其他的细节。
解决方案
格式化输出单个数字的时候,可以使用内置的 format()
函数,比如:
> x = 1234.56789 > # Two decimal places of accuracy > format(x, '0.2f') '1234.57' > # Right justified in 10 chars, one-digit accuracy > format(x, '>10.1f') ' 1234.6' > # Left justified > format(x, '<10.1f') '1234.6 ' > # Centered > format(x, '^10.1f') ' 1234.6 ' > # Inclusion of thousands separator > format(x, ',') '1,234.56789' > format(x, '0,.1f') '1,234.6' >
如果你想使用指数记法,将f改成e或者E(取决于指数输出的大小写形式)。比如:
> format(x, 'e') '1.234568e+03' > format(x, '0.2E') '1.23E+03' >
同时指定宽度和精度的一般形式是 讨论 数字格式化输出通常是比较简单的。上面演示的技术同时适用于浮点数和 当指定数字的位数后,结果值会根据 包含千位符的格式化跟本地化没有关系。 如果你需要根据地区来显示千位符,你需要自己去调查下 在很多Python代码中会看到使用%来格式化数字的,比如: 这种格式化方法也是可行的,不过比更加先进的 以上就是Python实现数字的格式化输出的详细内容,更多关于Python 数字格式化输出的资料请关注其它相关文章!'[<>^]"htmlcode">
> 'The value is {:0,.2f}'.format(x)
'The value is 1,234.57'
>
decimal
模块中的 Decimal
数字对象。round()
函数同样的规则进行四舍五入后返回。比如:
> x
1234.56789
> format(x, '0.1f')
'1234.6'
> format(-x, '0.1f')
'-1234.6'
>
locale
模块中的函数了。 你同样也可以使用字符串的 translate()
方法来交换千位符。比如:
> swap_separators = { ord('.'):',', ord(','):'.' }
> format(x, ',').translate(swap_separators)
'1.234,56789'
>
> '%0.2f' % x
'1234.57'
> '%10.1f' % x
' 1234.6'
> '%-10.1f' % x
'1234.6 '
>
format()
要差一点。 比如,在使用%操作符格式化数字的时候,一些特性(添加千位符)并不能被支持。
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
更新日志
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]