Python不使用科学计数输出

当我执行以下代码时,得到的均为科学计数输出结果。

import torch
import numpy as np

python的科学计数输出
print('科学计数输出 in python:', 0.0000000000000000002554, 0.91)

numpy中的科学计数输出
print('科学计数输出 in numpy:', np.array([0.0000000000000000002554, 0.91]))

pytorch中的科学计数输出
print('科学计数输出 in pytorch:', torch.tensor([0.0000000000000000002554, 0.91]))

科学计数输出 in python: 2.554e-19 0.91
科学计数输出 in numpy: [2.554e-19 9.100e-01]
科学计数输出 in pytorch: tensor([2.5540e-19, 9.1000e-01])

然而,尽管它很科学,有时候还是觉得这样的输出并不够直观。因此,如果想要看到非科学计数法表示的数字输出,那么我们该怎么办呢?

实际上没有太过于完美的解决方案,但我是这么做的

import torch
import numpy as np

python的科学计数输出
print('科学计数输出 in python:', 0.0000000000000000002554, 0.91)
关闭python的科学计数输出
print('非科学计数输出 in python: %.4f %.4f' % (0.0000000000000000002554, 0.91))

numpy中的科学计数输出
print('科学计数输出 in numpy:', np.array([0.0000000000000000002554, 0.91]))
关闭numpy中的科学计数输出
np.set_printoptions(precision=4, suppress=True)
print('非科学计数输出 in numpy:', np.array([0.0000000000000000002554, 0.91]))

pytorch中的科学计数输出
print('科学计数输出 in pytorch:', torch.tensor([0.0000000000000000002554, 0.91]))
关闭pytorch中的科学计数输出
torch.set_printoptions(precision=4, sci_mode=False)
print('非科学计数输出 in pytorch:', torch.tensor([0.0000000000000000002554, 0.91]))

输出如下

科学计数输出 in python: 2.554e-19 0.91
非科学计数输出 in python: 0.0000 0.9100
科学计数输出 in numpy: [2.554e-19 9.100e-01]
非科学计数输出 in numpy: [0. 0.91]
科学计数输出 in pytorch: tensor([2.5540e-19, 9.1000e-01])
非科学计数输出 in pytorch: tensor([ 0.0000, 0.9100])

可以看到,如果小数精确位数设置得不对的话,就会丢失一些信息。当然,你可以设定很多的精确位,以确保打印的数字不会丢失精度,然而,这样打印就不美观了,因为如果精确位设置得过大那么就会打印出很多位多余的0。因此,以上解决方案均不是很完美,仅供参考。不过想一想,应该还是有办法解决去除多余的0的,我是说,通过自己写一个算法的方式。

Original: https://blog.csdn.net/qq_36158230/article/details/120903217
Author: 飞机火车巴雷特
Title: Python不使用科学计数输出

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/758529/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

亲爱的 Coder【最近整理,可免费获取】👉 最新必读书单  | 👏 面试题下载  | 🌎 免费的AI知识星球