>백엔드 개발 >Golang >Go float64 값을 최대 유효 자릿수를 갖는 고정 너비 문자열로 형식화하는 방법은 무엇입니까?

Go float64 값을 최대 유효 자릿수를 갖는 고정 너비 문자열로 형식화하는 방법은 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2024-12-03 18:31:10823검색

How to Format a Go float64 Value into a Fixed-Width String with Maximum Significant Digits?

Go에서 Float64를 최대 유효 자릿수를 갖는 고정 너비 문자열로 변환하는 방법

Go에서 고정 너비 내에서 float64 값을 인쇄할 때 너비 테이블에서는 가능한 많은 유효 숫자를 유지하는 것이 바람직한 경우가 많습니다. 그러나 기본 형식을 사용하면 큰 숫자에 대해 과학적 표기법으로 자동 전환되므로 정밀도가 떨어질 수 있습니다.

사용자 정의 형식 지정 솔루션의 필요성

다음과 같은 경우 과학적 표기법과 정규 형식은 모두 허용되지 않으므로 맞춤형 형식 지정 접근 방식이 필요합니다. 주요 초점은 최대 유효 자릿수를 유지하면서 지정된 너비에 맞는 최적의 정밀도를 계산하는 것입니다.

제안된 솔루션

다음 구현은 간단한 솔루션을 제공합니다.


// format12 형식 x는 12자 long.
func format12(x float64) string {

if x >= 1e12 {
    s := fmt.Sprintf("%.g", x)
    format := fmt.Sprintf("%%12.%dg", 12-len(s))
    return fmt.Sprintf(format, x)
}

s := fmt.Sprintf("%.0f", x)
if len(s) == 12 {
    return s
}
format := fmt.Sprintf("%%%d.%df", len(s), 12-len(s)-1)
return fmt.Sprintf(format, x)

}

이 솔루션은 2단계 프로세스를 사용합니다.

  1. 결정 정밀도:

    • 1e12보다 크거나 같은 값의 경우 적절한 정밀도를 갖는 과학 표기법이 사용됩니다.
    • 더 작은 값의 경우 충분한 정밀도를 갖는 일반 형식이 사용됩니다. 정수의 길이를 기준으로 계산됩니다. 부분.
  2. 형식 문자열 생성:

    • 계산된 정밀도를 기반으로 사용자 정의 형식 문자열이 구성됩니다. 원하는 고정을 보장 width.

샘플 사용법 및 출력

기능을 보여주기 위해 몇 가지 샘플 값을 고려해 보겠습니다.


fs := []float64{0, 1234.567890123, 0.1234567890123, 123456789012.0, 1234567890123.0,

9.405090880450127e+9, 9.405090880450127e+19, 9.405090880450127e+119}

for _, f := 범위 fs {

fmt.Println(format12(f))

}

출력:

<br>0.000 0000000<br>0.1234567890<br>1234.5678901<br>123456789012<br>1.234568e 12<br>9405090880.5<br>9.405091e 19<br>9.40509e 119<br>

이 솔루션은 최대 유효 자릿수를 유지하면서 원하는 고정 너비 서식을 제공하므로 명확하고 다양한 float64 값을 간결하게 표시 시나리오.

위 내용은 Go float64 값을 최대 유효 자릿수를 갖는 고정 너비 문자열로 형식화하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.