Active Support Duration¶ ↑
提供准确的日期和时间测量,分别使用 Date#advance 和 Time#advance。它主要支持 Numeric 上的方法。
1.month.ago # equivalent to Time.now.advance(months: -1)
命名空间
方法
- #
- A
- B
- E
- F
- H
- I
- P
- S
- T
- U
常量
| PARTS | = | [:years, :months, :weeks, :days, :hours, :minutes, :seconds].freeze |
| PARTS_IN_SECONDS | = | { seconds: 1, minutes: SECONDS_PER_MINUTE, hours: SECONDS_PER_HOUR, days: SECONDS_PER_DAY, weeks: SECONDS_PER_WEEK, months: SECONDS_PER_MONTH, years: SECONDS_PER_YEAR }.freeze |
| SECONDS_PER_DAY | = | 86400 |
| SECONDS_PER_HOUR | = | 3600 |
| SECONDS_PER_MINUTE | = | 60 |
| SECONDS_PER_MONTH | = | 2629746 |
| SECONDS_PER_WEEK | = | 604800 |
| SECONDS_PER_YEAR | = | 31556952 |
| VARIABLE_PARTS | = | [:years, :months, :weeks, :days].freeze |
Attributes
| [R] | value |
类公共方法
build(value) Link
从秒值创建新的 Duration,该值会被转换为各个部分。
ActiveSupport::Duration.build(31556952).parts # => {:years=>1} ActiveSupport::Duration.build(2716146).parts # => {:months=>1, :days=>1}
# File activesupport/lib/active_support/duration.rb, line 189 def build(value) unless value.is_a?(::Numeric) raise TypeError, "can't build an #{self.name} from a #{value.class.name}" end parts = {} remainder_sign = value <=> 0 remainder = value.round(9).abs variable = false PARTS.each do |part| unless part == :seconds part_in_seconds = PARTS_IN_SECONDS[part] parts[part] = remainder.div(part_in_seconds) * remainder_sign remainder %= part_in_seconds unless parts[part].zero? variable ||= VARIABLE_PARTS.include?(part) end end end unless value == 0 parts[:seconds] = remainder * remainder_sign new(value, parts, variable) end
parse(iso8601duration) Link
从符合 ISO 8601 Duration 格式的字符串创建新的 Duration。
有关更多信息,请参阅 ISO 8601。此方法允许在模式中出现负数部分。如果提供无效字符串,将引发 ActiveSupport::Duration::ISO8601Parser::ParsingError。
实例公共方法
%(other) Link
*(other) Link
# File activesupport/lib/active_support/duration.rb, line 287 def *(other) if Scalar === other || Duration === other Duration.new(value * other.value, @parts.transform_values { |number| number * other.value }, @variable || other.variable?) elsif Numeric === other Duration.new(value * other, @parts.transform_values { |number| number * other }, @variable) else raise_type_error(other) end end
+(other) Link
# File activesupport/lib/active_support/duration.rb, line 268 def +(other) if Duration === other parts = @parts.merge(other._parts) do |_key, value, other_value| value + other_value end Duration.new(value + other.value, parts, @variable || other.variable?) else seconds = @parts.fetch(:seconds, 0) + other Duration.new(value + other, @parts.merge(seconds: seconds), @variable) end end
-(other) Link
/(other) Link
# File activesupport/lib/active_support/duration.rb, line 298 def /(other) if Scalar === other Duration.new(value / other.value, @parts.transform_values { |number| number / other.value }, @variable) elsif Duration === other value / other.value elsif Numeric === other Duration.new(value / other, @parts.transform_values { |number| number / other }, @variable) else raise_type_error(other) end end
<=>(other) Link
ago(time = ::Time.current) Link
hash() Link
in_days() Link
将一个持续时间包含的天数返回为浮点数。
12.hours.in_days # => 0.5
in_hours() Link
将一个持续时间包含的小时数返回为浮点数。
1.day.in_hours # => 24.0
in_minutes() Link
将一个持续时间包含的分钟数返回为浮点数。
1.day.in_minutes # => 1440.0
in_months() Link
将一个持续时间包含的月数返回为浮点数。
9.weeks.in_months # => 2.07
in_weeks() Link
将一个持续时间包含的周数返回为浮点数。
2.months.in_weeks # => 8.696
in_years() Link
将一个持续时间包含的年数返回为浮点数。
30.days.in_years # => 0.082
parts() Link
返回定义该持续时间的部分哈希的副本。
5.minutes.parts # => {:minutes=>5} 3.years.parts # => {:years=>3}
since(time = ::Time.current) Link
to_i() Link
返回此 Duration 所表示的秒数。
1.minute.to_i # => 60 1.hour.to_i # => 3600 1.day.to_i # => 86400
请注意,此转换对某些期间的持续时间做出了某些假设,例如:月份始终是年的 1/12,年是 365.2425 天。
# equivalent to (1.year / 12).to_i 1.month.to_i # => 2629746 # equivalent to 365.2425.days.to_i 1.year.to_i # => 31556952
也别名为: in_seconds