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단계 프로세스를 사용합니다.
결정 정밀도:
형식 문자열 생성:
샘플 사용법 및 출력
기능을 보여주기 위해 몇 가지 샘플 값을 고려해 보겠습니다.
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!