Float를 소수점 이하 두 자리로 제한
round()와 같은 표준 방법을 사용하여 실수를 소수점 두 자리로 반올림하려고 하면 예상치 못한 결과가 발생할 수 있습니다. . 이는 특정 숫자를 정확하게 표현할 수 없는 부동 소수점 표현의 본질적인 한계 때문입니다.
이진 컴퓨터에서 부동 소수점 숫자는 2의 거듭제곱으로 나눈 정수로 저장됩니다. 예를 들어 13.95는 대략 125650429603636838/(2**53)으로 표시됩니다. 부동 소수점 유형은 정밀도가 제한되어 있으므로(부동 소수점의 경우 24비트, 이중 정밀도의 경우 53비트) 이러한 값을 항상 정확하게 표현할 수는 없습니다.
결과적으로 round()를 사용하여 부동 소수점 숫자를 반올림하면 다음과 같은 결과가 발생할 수 있습니다. 약간 벗어난 결과를 생성합니다. 표시 목적으로 원하는 소수점 이하 두 자리 정밀도를 얻으려면 다음과 같은 대체 접근 방식을 사용할 수 있습니다.
예를 들어 다음 연산은 십진수 두 개로 올바르게 반올림됩니다. 표시 장소:
print("%.2f" % a) # -> 13.95 print("{:.2f}".format(a)) # -> 13.95
"{:.15f}".format(round(a, 2))를 사용하면 부동 소수점 숫자의 정밀도 제한으로 인해 13.949999999999999가 반환됩니다. 그러나 표시 목적에서는 이 정도의 정밀도가 필요하지 않습니다.
위 내용은 플로트를 소수점 이하 두 자리까지 안정적으로 반올림하여 표시하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!