Convert a scientific notation to decimal number, and still keeping the data format as float64

doganadres at gmail.com doganadres at gmail.com
Fri Oct 18 09:03:40 EDT 2019


On Friday, October 18, 2019 at 2:21:34 PM UTC+3, Richard Damon wrote:
> On 10/18/19 4:35 AM, doganadres at gmail.com wrote:
> > Here is my question:
> >
> >
> > I am using the numpy.std formula to calculate the standart deviation. However, the result comes as a number in scientific notation.
> > Therefore I am asking, How to convert a scientific notation to decimal number, and still keep the data format as float64 ?
> >
> > Or is there any workaround to get the initial standart deviation result as a decimal number?
> >
> >
> > Here is my code:
> >
> > stdev=numpy.std(dataset)
> > print(stdev)
> >     Result: 4.999999999999449e-05
> >
> >
> > print(stdev.dtype)
> >     Result: float64
> >
> >
> > Solutions such as this:
> >
> > stdev=format(stdev, '.10f')
> > converts the data into a string object! which I don't want.
> >
> >
> > Expected result: I am willing to have a result as a decimal number in a float64 format.
> >
> > System: (Python 3.7.4 running on Win10)
> >
> >
> > Regards, 
> 
> The number itself isn't in scientific notation or a fixed point number,
> but is a floating point number that is expressed internally as an
> integer times a power of 2 (that is the basic representation format for
> floating point).
> 
> Scientific notation vs fixed point notation is purely an OUTPUT
> configuration, not a function on how the number is stored (so in one
> sense IS more closely linked to a string than the float itself).
> 
> -- 
> Richard Damon


Hello Richard,

You seem so right. But what will we do with those strings with 'e' in it?

There are ways to present those in a 'normal' way with formatting. However, the result of those formatting turns them into str object and which limits you to do any further numerical things with them.

Another thing which I have observed, while doing some experimental thing is that:

>>> 0.0
0.0

>>> 0.1
0.1

>>> 0.01
0.01

>>> 0.001
0.001

>>> 0.0001
0.0001

>>> 0.00001
1e-05

Again another thing with 1e-05! instead of 0.00001 , Is there anything I can do about it?



More information about the Python-list mailing list