반올림에 문제가 있습니다. 부동 소수점이 있습니다. 소수점을 100으로 반올림하고 싶습니다. 그러나 .round
기본적으로 int로 변환하는 것을 사용할 수 있습니다 . 즉, 2.34.round # => 2.
다음과 같은 간단한 효과 방법이 있습니까?2.3465 # => 2.35
반올림에 문제가 있습니다. 부동 소수점이 있습니다. 소수점을 100으로 반올림하고 싶습니다. 그러나 .round
기본적으로 int로 변환하는 것을 사용할 수 있습니다 . 즉, 2.34.round # => 2.
다음과 같은 간단한 효과 방법이 있습니까?2.3465 # => 2.35
답변:
표시 할 때 (예를 들어)
>> '%.2f' % 2.3465
=> "2.35"
둥근 모양으로 저장하려면
>> (2.3465*100).round / 100.0
=> 2.35
2.3000.round(2) => 2.3
하고 sprintf '%.2f', 2.300 => 2.30
. 내 생각에 이것은 round ()의 결함이거나 후행 0을 유지하는 옵션이 있어야합니다.
2.3000.round(2)
는 문자열이 아닌 숫자입니다. 숫자 2.3
가와 다른 2.30
방법은 없으므로 후행 0을 유지하는 옵션이 없습니다. 자신 만의 numbers_with_significance 클래스를 만들 수 있지만 이미 문자열이 있습니다.
'%.3f' % 1.2345
(3 소수점이 아닌 2) 그러나! sprintf
마찬가지로 동일합니다 . 조심하십시오. 대부분의 예상대로 반환 => 1.234
되지 않습니다 ( 즉 => 1.235
, 소수점 둘째 자리 이후에 sprintf는 5를 내림 하고 6을 올림합니다). 이것이 바로 위의 Kit Ho의 의견이 25 개 이상의 공감대를 갖는 이유입니다. 사용하기에 안전 '%.3f' % 1.2345.round(3)
하므로 먼저 숫자를 올림 한 .round
다음 형식을 지정합니다 (필요한 경우 후행 0으로).
반올림 할 소수점 이하 자릿수를 포함하는 반올림에 인수를 전달하십시오.
>> 2.3465.round
=> 2
>> 2.3465.round(2)
=> 2.35
>> 2.3465.round(3)
=> 2.347
1.1.round(2)
=> 1.1
not1.10
Float Class에 메소드를 추가 할 수 있습니다.
class Float
def precision(p)
# Make sure the precision level is actually an integer and > 0
raise ArgumentError, "#{p} is an invalid precision level. Valid ranges are integers > 0." unless p.class == Fixnum or p < 0
# Special case for 0 precision so it returns a Fixnum and thus doesn't have a trailing .0
return self.round if p == 0
# Standard case
return (self * 10**p).round.to_f / 10**p
end
end
그냥 표시해야한다면 number_with_precision 도우미를 사용하십시오 . 당신이 다른 곳이 필요하면 스티브 Weet가 지적했듯이 나는, 사용하는 것입니다 round
방법을
number_with_precision
레일 전용 방법입니다.
sprintf '%.2f', 2.3465
작동합니다.