[英]How does Python determine whether to represent a number using scientific notation or not?
以下是在Python控制台中输入的一些数字及其结果表示形式:
>>> 1
1
>>> 1.234
1.234
>>> 1.234e5
123400.0
>>> 1.234e15
1234000000000000.0
>>> 1.234e25
1.234e+25
...当打印相同的数字时会发生以下情况:
>>> print 1
1
>>> print 1.234
1.234
>>> print 1.234e5
123400.0
>>> print 1.234e15
1.234e+15 # different!
>>> print 1.234e25
1.234e+25
Python如何决定要使用哪种表示形式? 为什么某些数字有无print
会有所不同?
在Python中使用科学计数法仅表示浮点数; 整数始终按原样表示。
如何在Python 2.7中表示浮点数取决于它是使用repr()
(例如,直接在控制台中还是作为集合的成员)还是str()
(例如,使用print
语句)表示的。
使用repr()
,如果浮点数小于0.0001
( 1e-4
)或至少为1e16
,则使用科学计数法表示1e16
:
>>> 1e-4
0.0001
>>> 0.00009999
9.999e-05
>>> 1e16-2
9999999999999998.0
>>> 10000000000000000.0
1e+16
使用str()
,上限大约为1e11
:
>>> print 1e11-1
99999999999.0
>>> print 100000000000.0
1e+11
注意:在Python 3中, str()
现在以与repr()
相同的方式表示浮点数。
数字值只是存储为值。 __repr__
输出可能会根据数字的实现和类型而改变。 您需要格式化数字的字符串表示形式。
例:
>>> type(1e3) is type(1000.0) # float
True
>>> type(1e3) is type(1000) # int
False
格式化字符串时,可以使用%g
/ {:g}
使其自动确定最易读的格式。 使用%e
/ {:e}
表示明确的科学符号。
>>> x = 1234567
>>> "{:.2e}".format(x)
1.23e+06
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.