7

毎日created_atでグループ化された動画を投稿するためのループを取得しようとしています。

例えば:

2012年12月5日-ビデオ9ビデオ8ビデオ7

2012年12月4日-ビデオ6ビデオ5

2012年12月3日-ビデオ4ビデオ3ビデオ2ビデオ1

videos_controller:

  def index
    @title = 'Hip Hop Videos, Breaking News, Videos, And Funny Shxt | HOTDROPHIPHOP'
    @description = ''
    @videos = Video.all
    @days = Video.where(:created_at == Time.today )
  end

ファイルを閲覧する:

<% @days.each do |day| %>

  <div class="video-date">December 4, 2012</div>

  <% @videos.each do |video| %>
  <% end %>

<% end %>

また、その日の日付を表示するためにそのdivを取得する必要があります。

私は周りを検索して解決策を見つけることができず、group_by(最もクリーンに見えた)を試しましたが、それを機能させることができませんでした。Railsに何ヶ月も触れていないので、少し錆びています。

4

4 に答える 4

17

あなたはこれを行うことができます:

@videos = Video.where(Video.arel_table[:created_at].gteq(some_date_value))
@video_days = @videos.group_by {|video| video.created_at.to_date }

@video_daysの形式のハッシュはどこになりますか{some_date_value: [{video1}, {video2}, etc], next_date_value: [{video3}, {video4}, etc], etc...}

あなたは現場で電話.to_dateしているのでcreated_at、すべての時間情報が削除され、すべてが効果的に日ごとにグループ化されます.

次のようにループできます。

<% @video_days.each do |day, videos| %>
  <%= day.strftime("some format") %>
  <% videos.each do |video| %>
    <%= #output videos how you see fit %>
  <% end %>
<% end %>
于 2012-12-06T17:24:28.317 に答える
3

最善の方法は、gem Groupdateを使用することです

例えば User.group_by_day(:created_at).count

日単位、週単位、時間単位で注文できます

于 2016-07-25T21:48:57.857 に答える
1

まず、今日のビデオだけを呼び出してから、すべてのビデオを実行するのは意味がありません。

私はこのようにしてみます:

コントローラ

@videos = Video.all(:conditions => ["created_at >= ?", Date.today.at_beginning_of_month])

意見

<% Date.today.at_beginning_of_month.upto(Date.today).each do |date| %>
  <%= date %>: <%= @videos.select{|u| u.created_at == date }.title %>
<% end %>

実際の月の「日付: ビデオ タイトル」を含むビデオ リストが表示されます。

于 2012-12-06T17:07:49.967 に答える
0

あなたがmysqlを使用していて、ビデオに属性タイトルがあると仮定すると、ロジックを理解するのに役立つ次のコードを投稿しています(確かにリファクタリングが必要です)

コントローラ

@videos = {}
videos =  Video.order("DATE(created_at) DESC, title ASC").select("DATE(created_at) as created_at, title, id" )

videos.collect{|x| @videos[x.created_at.to_s] = @videos[x.created_at.to_s] ? @videos[x.created_at.to_s] << x.title : [x.title]  }

見る

<% @videos.each do |posted_date, videos| %>
  <div class="video-date"><%= Date.parse(posted_date.to_s).strftime("%b %d, %Y") %> </div> 
  <%= videos.join(", ") %>
 <% end %>
于 2012-12-06T17:20:52.443 に答える