- mongodb - 在 MongoDB mapreduce 中,如何展平值对象?
- javascript - 对象传播与 Object.assign
- html - 输入类型 ="submit"Vs 按钮标签它们可以互换吗?
- sql - 使用 MongoDB 而不是 MS SQL Server 的优缺点
我想打印一些 float ,以便它们始终以十进制形式写入(例如 12345000000000000000000.0
或 0.000000000000012345
,不在 scientific notation 中,但我想要结果是 IEEE 754 double 最高可达 ~15.7 significant figures,仅此而已。
我想要的是 ideally 以便结果是位置十进制格式的 最短 字符串,当转换为 float
.
众所周知,如果指数大于 15 或小于 -4,则 float
的 repr
以科学计数法编写:
>>> n = 0.000000054321654321
>>> n
5.4321654321e-08 # scientific notation
如果使用了str
,结果字符串又是科学计数法:
>>> str(n)
'5.4321654321e-08'
有人建议我可以使用带有 f
标志的 format
和足够的精度来摆脱科学记数法:
>>> format(0.00000005, '.20f')
'0.00000005000000000000'
它适用于该数字,尽管它有一些额外的尾随零。但是对于 .1
,同样的格式会失败,它给出的十进制数字超出了 float 的实际机器精度:
>>> format(0.1, '.20f')
'0.10000000000000000555'
如果我的号码是 4.5678e-20
,使用 .20f
仍然会失去相对精度:
>>> format(4.5678e-20, '.20f')
'0.00000000000000000005'
因此这些方法不符合我的要求。
这导致了一个问题:以十进制格式打印任意 float 的最简单且性能良好的方法是什么,与 repr(n)
(or str(n)
on Python 3) 具有相同的数字,但始终使用十进制格式,而不是科学记数法。
即例如将浮点值0.00000005
转换为字符串'0.00000005'
的函数或操作; 0.1
到 '0.1'
; 420000000000000000.0
到 '420000000000000000.0'
或 420000000000000000
并将浮点值 -4.5678e-5
格式化为 ' -0.000045678'
.
在赏金期之后:似乎至少有两种可行的方法,正如 Karin 证明的那样,与我在 Python 2 上的初始算法相比,使用字符串操作可以显着提高速度。
因此,
decimal
模块由于某种原因不能使用,那么 Karin's approach using string manipulation 就是这样做的方法。由于我主要在 Python 3 上进行开发,我将接受我自己的答案,并将奖励 Karin。
最佳答案
不幸的是,似乎连带有 float.__format__
的新格式格式都不支持这一点。 float
s 的默认格式与 repr
相同;并且带有 f
标志,默认情况下有 6 个小数位:
>>> format(0.0000000005, 'f')
'0.000000'
然而,有一个技巧可以得到想要的结果——不是最快的,但相对简单:
str()
或 repr()
Decimal
实例是从该字符串创建的。Decimal.__format__
支持提供所需结果的 f
标志,并且与 float
不同,它打印实际精度而不是默认精度.因此我们可以制作一个简单的效用函数float_to_str
:
import decimal
# create a new context for this task
ctx = decimal.Context()
# 20 digits should be enough for everyone :D
ctx.prec = 20
def float_to_str(f):
"""
Convert the given float to a string,
without resorting to scientific notation
"""
d1 = ctx.create_decimal(repr(f))
return format(d1, 'f')
必须注意不要使用全局十进制上下文,因此为此函数构造了一个新上下文。这是最快的方法;另一种方法是使用 decimal.local_context
但它会更慢,为每次转换创建一个新的线程本地上下文和一个上下文管理器。
此函数现在返回包含尾数中所有可能数字的字符串,四舍五入为 shortest equivalent representation :
>>> float_to_str(0.1)
'0.1'
>>> float_to_str(0.00000005)
'0.00000005'
>>> float_to_str(420000000000000000.0)
'420000000000000000'
>>> float_to_str(0.000000000123123123123123123123)
'0.00000000012312312312312313'
最后一位结果四舍五入
正如@Karin 所说,float_to_str(420000000000000000.0)
与预期的格式不完全匹配;它返回 420000000000000000
而没有尾随 .0
。
关于python - 将 float 转换为位置格式的字符串(没有科学记数法和错误精度),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38847690/
我正在尝试将一个字符串逐个字符地复制到另一个字符串中。目的不是复制整个字符串,而是复制其中的一部分(我稍后会为此做一些条件......) 但我不知道如何使用迭代器。 你能帮帮我吗? std::stri
我想将 void 指针转换为结构引用。 结构的最小示例: #include "Interface.h" class Foo { public: Foo() : mAddress((uint
这有点烦人:我有一个 div,它从窗口的左上角开始过渡,即使它位于文档的其他任何位置。我试过 usign -webkit-transform-origin 但没有成功,也许我用错了。有人可以帮助我吗?
假设,如果将 CSS3 转换/转换/动画分配给 DOM 元素,我是否可以检测到该过程的状态? 我想这样做的原因是因为我正在寻找类似过渡链的东西,例如,在前一个过渡之后运行一个过渡。 最佳答案 我在 h
最近我遇到了“不稳定”屏幕,这很可能是由 CSS 转换引起的。事实上,它只发生在 Chrome 浏览器 上(可能还有 Safari,因为一些人也报告了它)。知道如何让它看起来光滑吗?此外,您可能会注意
我正在开发一个简单的 slider ,它使用 CSS 过渡来为幻灯片设置动画。我用一些基本样式和一些 javascript 创建了一支笔 here .注意:由于 Codepen 使用 Prefixfr
我正在使用以下代码返回 IList: public IList FindCodesByCountry(string country) { var query =
如何设计像这样的操作: 计算 转化 翻译 例如:从“EUR”转换为“CNY”金额“100”。 这是 /convert?from=EUR&to=CNY&amount=100 RESTful 吗? 最佳答
我使用 jquery 组合了一个图像滚动器,如下所示 function rotateImages(whichHolder, start) { var images = $('#' +which
如何使用 CSS (-moz-transform) 更改一个如下所示的 div: 最佳答案 你可以看看Mozilla Developer Center .甚至还有例子。 但是,在我看来,您的具体示例不
我需要帮助我正在尝试在选中和未选中的汉堡菜单上实现动画。我能够为菜单设置动画,但我不知道如何在转换为 0 时为左菜单动画设置动画 &__menu { transform: translateX(
我正在为字典格式之间的转换而苦苦挣扎:我正在尝试将下面的项目数组转换为下面的结果数组。本质上是通过在项目第一个元素中查找重复项,然后仅在第一个参数不同时才将文件添加到结果集中。 var items:[
如果我有两个定义相同的结构,那么在它们之间进行转换的最佳方式是什么? struct A { int i; float f; }; struct B { int i; float f; }; void
我编写了一个 javascript 代码,可以将视口(viewport)从一个链接滑动到另一个链接。基本上一切正常,你怎么能在那里看到http://jsfiddle.net/DruwJ/8/ 我现在的
我需要将文件上传到 meteor ,对其进行一些图像处理(必要时进行图像转换,从图像生成缩略图),然后将其存储在外部图像存储服务器(s3)中。这应该尽可能快。 您对 nodejs 图像处理库有什么建议
刚开始接触KDB+,有一些问题很难从Q for Mortals中得到。 说,这里 http://code.kx.com/wiki/JB:QforMortals2/casting_and_enumera
我在这里的一个项目中使用 JSF 1.2 和 IceFaces 1.8。 我有一个页面,它基本上是一大堆浮点数字段的大编辑网格。这是通过 inputText 实现的页面上的字段指向具有原始值的值对象
ScnMatrix4 是一个 4x4 矩阵。我的问题是什么矩阵行对应于位置(ScnVector3),旋转(ScnVector4),比例(ScnVector3)。第 4 行是空的吗? 编辑: 我玩弄了
恐怕我是 Scala 新手: 我正在尝试根据一些简单的逻辑将 Map 转换为新 Map: val postVals = Map("test" -> "testing1", "test2" -> "te
输入: This is sample 1 This is sample 2 输出: ~COLOR~[Green]This is sample 1~COLOR~[Red]This is sam
我是一名优秀的程序员,十分优秀!