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", ..]
4

4 に答える 4

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)}
于 2012-12-13T01:49:59.603 に答える
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}}
于 2012-12-13T03:34:34.620 に答える
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") }
于 2012-12-13T04:39:50.057 に答える
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]}

しかし、これらの日付がデータベース テーブルから取得されている場合は、そこで並べ替えることを検討できます。その方が少し速くなります (特にレコードが多い場合)。

于 2012-12-13T01:39:00.620 に答える