这个问题必须简单,但我在这里找不到任何相关内容。
在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命令行。
答案 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)]
要将任何对象转换为字符串表示形式,请将其传递给repr
或str
,例如
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')
当然,如果您既需要速度又需要高精度,那么您也可以使用mpmath
或gmpy
这样的模块,但我认为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
试一试。