2012-12-13 158 views
1

在Ruby on Rails中,我有一组数据需要过滤以获取每月最近创建的数据。什么是最佳优化的方式来做到这一点?从日期集合中选择每个月的最后日期

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

结果应该是

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

哪里是你的它的版本? – oldergod

+0

输入中的嵌套数组和结果中的平面数组之间的关系是什么?不清楚。 – sawa

+0

感谢您提到这一点。让我们假设它不是一个嵌套数组,而是一个包含日期的数组。 – Ashan

回答

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

为什么'Date.new(* date_string.split(“ - ”)。map {| d | d.to_i})'当您可以执行'Date .parse(DATE_STRING)'? –

+0

我不喜欢魔法。 –

+2

'Date.parse'如何变魔术?只要你知道它做了什么以及它是如何做到的,它就不是魔术。如果你不知道,那么学习,而不是彻底放弃它。 –

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]} 

但如果这些日期出来一个数据库表的,也许你可以考虑排序它在那里。这会更快一些(特别是如果有很多记录)。

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}} 
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") } 
相关问题