用于舍入浮点数的Python超参数

时间:2017-12-04 07:08:05

标签: python floating-point precision

这个问题必须简单,但我在这里找不到任何相关内容。

在python中是否有一种方法可以定义或使用1个命令行,以便X挖掘者可以对脚本中的每个浮点数进行舍入。

例如,如果我定义:

max_float_digits = 4

并且程序想要输出或打印以下数字5.1355895682,我将看到5.1356

当某个模块将此值返回到我的脚本时,这种必要性会上升:

[('user_ctr', 2253.459088429824), ('user_clicks', 2042.3175666666664), ('t_avg_sim', 176.83513843049306), ('item_ctr', 137.6051319164618), ('item_age', 128.52122456437388), ('t_max_sim', 126.23752629310347), ('item_read_time', 46.94452635514022), ('clicks', 26.368489035532996), ('likes', 15.43922933884298), ('c_max_sim', 14.761540559999993), ('no_clicks', 13.020515220883516), ('c_avg_sim', 10.969965476190472), ('user_read_time', 10.21293115646259), ('user_age', 9.776781678832117)]

我没有试图访问每个值并围绕它们,而是想要一个将它们全部围绕它的1命令行。

3 个答案:

答案 0 :(得分:2)

抱歉,Python不提供控制格式的全局设置。如果您不想以完全精度显示浮动,则需要显式格式化它们。我认为打印包含浮动的集合时不太方便。但是,Python的集合对象(tuple,list,dict,set)的__repr__主要用于向程序员而不是用户显示这些对象。如果您打算将这些对象显示给用户,而不是将它们转储到终端,则应该格式化这些对象。

如果要在多个位置使用相同的格式,可能需要定义一个函数。例如,

max_float_digits = 4
def rounded(val):
    return '{:.{}f}'.format(val, max_float_digits)

data = [
    ('user_ctr', 2253.459088429824), ('user_clicks', 2042.3175666666664), 
    ('t_avg_sim', 176.83513843049306), ('item_ctr', 137.6051319164618), 
    ('item_age', 128.52122456437388), ('t_max_sim', 126.23752629310347), 
    ('item_read_time', 46.94452635514022), ('clicks', 26.368489035532996), 
    ('likes', 15.43922933884298), ('c_max_sim', 14.761540559999993), 
    ('no_clicks', 13.020515220883516), ('c_avg_sim', 10.969965476190472), 
    ('user_read_time', 10.21293115646259), ('user_age', 9.776781678832117),
]

out_data = [(key, rounded(val)) for key, val in data]
for row in out_data:
    print(row)

<强>输出

('user_ctr', '2253.4591')
('user_clicks', '2042.3176')
('t_avg_sim', '176.8351')
('item_ctr', '137.6051')
('item_age', '128.5212')
('t_max_sim', '126.2375')
('item_read_time', '46.9445')
('clicks', '26.3685')
('likes', '15.4392')
('c_max_sim', '14.7615')
('no_clicks', '13.0205')
('c_avg_sim', '10.9700')
('user_read_time', '10.2129')
('user_age', '9.7768')

如果您确实需要列表的字符串表示形式,并且希望它看起来像问题中所示,则可以使用内置的round函数。

output = [(key, round(val, max_float_digits)) for key, val in data]
print(output)    

<强>输出

[('user_ctr', 2253.4591), ('user_clicks', 2042.3176), ('t_avg_sim', 176.8351), ('item_ctr', 137.6051), ('item_age', 128.5212), ('t_max_sim', 126.2375), ('item_read_time', 46.9445), ('clicks', 26.3685), ('likes', 15.4392), ('c_max_sim', 14.7615), ('no_clicks', 13.0205), ('c_avg_sim', 10.97), ('user_read_time', 10.2129), ('user_age', 9.7768)]

要将任何对象转换为字符串表示形式,请将其传递给reprstr,例如

s = repr(output)

答案 1 :(得分:0)

不,没有这样的参数,但是如果你不想使用十进制数而不是IEEE754浮点类型,你可以用decimal模块实现类似的功能。

请参阅示例(来自网址https://docs.python.org/2/library/decimal.html):

>>> from decimal import *
>>> getcontext().prec = 6
>>> Decimal(1) / Decimal(7)
Decimal('0.142857')
>>> getcontext().prec = 28
>>> Decimal(1) / Decimal(7)
Decimal('0.1428571428571428571428571429')

当然,如果您既需要速度又需要高精度,那么您也可以使用mpmathgmpy这样的模块,但我认为decimal在您自己的情况下值得一试(它是标准库中的模块。)

答案 2 :(得分:0)

如何定义自己的方法,并将其作为装饰器用于您需要以所需格式输出的每个方法:

试试这个样本:

import math
max_float_digits = 4
v = 8.8333333333333339
def hyper(v,max_no_float):
    rounding = pow(10,max_no_float)
    return (math.ceil(v * rounding) / rounding)
print hyper(v,max_float_digits)
print hyper(v,3)

输出:

>>>8.8334
>>>8.834

试一试。