0

我想恢复两个不同表中的数据并将数据放在excel上,但如果有人有想法,我会有一个小错误。谢谢

class ExportController < ApplicationController

def index
@attachments= Attachment.all
@projects= Project.all
 respond_to do |format|
  format.html
  format.csv {send_data @attachments.to_csv}
  format.xls {send_data @attachments.to_csv(col_sep: "\t") and send_data @projects.to_csv(col_sep: "\t")}

end

end 
end

路由.rb

get '/export', to: 'export#index'

模型..

class Export < ActiveRecord::Base

   def self.to_csv(options = {})
      CSV.generate(options) do |csv|
      csv << column_names
      all.each do |table|
      csv << table.attributes.values_at(*column_names)
      end
    end
  end

  end

看法

<h1>Exportation</h1>
<%= link_to 'Download as .xlsx', export_path(format: :xls) %>

模型(项目.rb)

  class Project < ActiveRecord::Base
    def self.to_csv(options = {})
    CSV.generate(options) do |csv|
    csv << column_names
    all.each do |project|
   csv << project.attributes.values_at(*column_names)
  end
  end
 end
end

模型(附件.rb)

class Attachment < ActiveRecord::Base
 def self.to_csv(options = {})
      CSV.generate(options) do |csv|
      csv << column_names
      all.each do |table|
      csv << table.attributes.values_at(*column_names)
      end
    end
  end
  end

错误图像

4

1 回答 1

0

您不能一次响应两次请求。一个选项是:

format.xls {send_data @attachments.to_csv(col_sep: "\t") + @projects.to_csv(col_sep: "\t") }

有了这个,您将回复一个包含附件和项目的文件。

于 2018-07-06T08:19:13.547 回答