Rails--export csv

--controller

def export_agent_impressions

  export_start_time = Time.parse(params[:es_time]) + 7.hours

  export_end_time = Time.parse(params[:ee_time]) + 31.hours

  impressions = AgentImpression.where("created_at >= ? and created_at < ?", export_start_time, export_end_time).order("created_at desc")

  respond_to do |format|

    format.html

    format.csv {send_data agent_impressions_csv(impressions), filename: "agent_impressions_#{time}.csv"}

  end

end

 

--send_data csv data

def agent_impressions_csv(impressions)

  CSV.generate(headers: true) do |csv|

    columns = AgentImpression.column_names

    csv << columns

    impressions.each do |impression|

      csv << columns.map{|c| impression[c]}

    end

end

转载于:https://www.cnblogs.com/gary-tao/p/5711084.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值