从日期集合中选择每个月的最后日期

时间:2012-12-13 01:20:57

标签: ruby-on-rails ruby

在Ruby on Rails中,我有一组数据需要过滤才能获得每个月最近创建的数据。什么是最佳优化方式?

e.g

["2012-1-2","2012-1-18", "2012-1-5", "2012-2-15","2012-2-23","2012-2-4"]

结果应该是

["2012-1-18, "2012-2-23", ..]

4 个答案:

答案 0 :(得分:2)

def last_in_month(dates)
  dates = dates.map {|date_string| Date.parse(date_string)}
  grouped_by_month = dates.group_by {|date| date.month}
  grouped_by_month.map do |month, dates_in_month|
    dates_in_month.max_by {|d| d.day}
  end
end

last_in_month(your_nested_arrays.flatten)

返回日期对象。

再次转换为字符串:)

last_in_month(your_nested_arrays.flatten).map {|d| d.to_s(:db)}

答案 1 :(得分:1)

["2012-1-2","2012-1-18", "2012-1-5", "2012-2-15","2012-2-23","2012-2-4"]
.group_by{|s| s[/\d+-\d+/]}
.values
.map{|a| a.max_by{|s| s[/\d+\z/].to_i}}

答案 2 :(得分:0)

这应该有效:

my_date = ["2012-1-2","2012-1-18", "2012-1-5", "2012-2-15","2012-2-23","2012-2-4"]
my_date.sort_by{|date| month,day,year=date.split("-");[year,month,day]}

但是如果这些日期来自数据库表,也许您可​​以考虑在那里进行排序。这会更快一点(特别是如果有很多记录)。

答案 3 :(得分:0)

["2012-1-2","2012-1-18", "2012-1-5", "2012-2-15","2012-2-23","2012-2-4"].map { |d| Date.parse(p) }.sort.group_by { |d| [d.month, d.year].join('/') }.map { |k,v| v.last.strftime("%Y-%-m-%-d") }