Преобразование целого числа в число с плавающей запятой


127

Как преобразовать целочисленное значение в float64тип?

Я попытался

float(integer_value)

Но это не работает. И не могу найти ни одного пакета, который делает это на Golang.org

Как получить float64значения из целочисленных значений?

Ответы:


180

floatТипа нет . Похоже, ты хочешь float64. Вы также можете использовать, float32если вам нужно только значение с плавающей запятой одинарной точности.

package main

import "fmt"

func main() {
    i := 5
    f := float64(i)
    fmt.Printf("f is %f\n", f)
}

Отметим, что компилятор go не понимает этого. a := uint(8); b := uint(5); c := float32(a/b)будет c1.00000, а не 1.6.
isomorphismes

34

Для полноты картины, вот ссылка на документацию golang, в которой описаны все типы . В вашем случае это числовые типы:

uint8       the set of all unsigned  8-bit integers (0 to 255)
uint16      the set of all unsigned 16-bit integers (0 to 65535)
uint32      the set of all unsigned 32-bit integers (0 to 4294967295)
uint64      the set of all unsigned 64-bit integers (0 to 18446744073709551615)

int8        the set of all signed  8-bit integers (-128 to 127)
int16       the set of all signed 16-bit integers (-32768 to 32767)
int32       the set of all signed 32-bit integers (-2147483648 to 2147483647)
int64       the set of all signed 64-bit integers (-9223372036854775808 to 9223372036854775807)

float32     the set of all IEEE-754 32-bit floating-point numbers
float64     the set of all IEEE-754 64-bit floating-point numbers

complex64   the set of all complex numbers with float32 real and imaginary parts
complex128  the set of all complex numbers with float64 real and imaginary parts

byte        alias for uint8
rune        alias for int32

Значит, нужно использовать float64(integer_value).


2

intutils.ToFloat32

// ToFloat32 converts a int num to a float32 num
func ToFloat32(in int) float32 {
    return float32(in)
}

// ToFloat64 converts a int num to a float64 num
func ToFloat64(in int) float64 {
    return float64(in)
}

0

Преобразование типов T (), где T - желаемый тип данных результата, в GoLang довольно просто.

В своей программе я просматриваю целое число i из пользовательского ввода, выполняю преобразование типа и сохраняю его в переменной f . На выходе печатается float64эквивалент intввода. float32тип данных также доступен в GoLang

Код:

package main
import "fmt"
func main() {
    var i int
    fmt.Println("Enter an Integer input: ")
    fmt.Scanf("%d", &i)
    f := float64(i)
    fmt.Printf("The float64 representation of %d is %f\n", i, f)
}

Решение:

>>> Enter an Integer input:
>>> 232332
>>> The float64 representation of 232332 is 232332.000000
Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.