我在python中有一个包含一组值的数组,其中一些是
2.32313e + 07
2.1155e + 07
1.923e + 07
11856
112.32
如何将指数格式转换为十进制格式
附加:在使用awk在UNIX中打印时,有没有办法可以将指数直接转换为十进制?
答案 0 :(得分:5)
我想你有一个列表而不是一个数组,但在这里并没有太大的区别;在2.6和早期版本的Python中,类似于:
>>> L = [2.32313e+07, 2.1155e+07, 1.923e+07, 11856, 112.32]
>>> for x in L: print '%f' % x
...
23231300.000000
21155000.000000
19230000.000000
11856.000000
112.320000
以及2.6或更高版本的.format
方法。我想你知道数字本身的数字不是任何“格式” - 它是你通过格式化数字获得的字符串,例如输出,以某种格式。顺便说一句,%f
上的变体可以让你控制小数位数,宽度,对齐等 - 如果没有你的进一步说明,很难准确地建议你想要什么。
在awk中,您可以使用printf。
答案 1 :(得分:1)
您可以使用locale.format()格式化输出数字。这具有额外的好处,即与数字表示中可能预期的任何特定于语言环境的约定一致。如果您想要在输出的特定位置进行完全控制,那么您最好使用 print“format”%vars ... variant。
示例:
>>> import locale
>>> locale.setlocale(locale.LC_ALL, "")
'C/UTF-8/C/C/C/C'
>>> locale.format("%f", 2.32313e+07, 1)
'23231300.000000'
答案 2 :(得分:0)
在回答问题的最后部分时,awk
可以使用相同的printf
格式:
awk '{printf "%f\n",$1}' exponential_file
exponential_file包含:
2.32313e+07
2.1155e+07
1.923e+07
11856
112.32
您可以转换为变量以供日后使用。这是一个简单的例子:
awk '{n = sprintf("%f\n",$1); print n * 2}' exponential_file