问题 在rails上的ruby中创建可下载文件


访问该页面

localhost:3000/download_me

在控制器foo中调用控制器动作download_me。

class foo < ApplicationController
  def download_me
    # a file is created here i.e. temp.csv in directory C:\
  end
end

控制器应创建一个临时csv文件,然后在访问该页面的浏览器中触发下载。

我怎样才能做到这一点?


7162
2018-05-23 13:23


起源



答案:


您是否有任何理由将临时文件存储在服务器上?如果是这样的话就足够了(使用 fastercsv,你需要安装):

require 'fastercsv'
FILE_PATH= "root/to/tmpfile.csv"

FasterCSV.open(FILE_PATH, "w") do |csv|
    csv << 'add some data'
end

send_file file_path, :type=>'text/csv'

我建议你可能不需要存储文件,所以只需用以下代码替换FasterCSV.open行:

csv = FasterCSV.generate do |csv|

然后吐出csv作为响应:

send_data csv, :type=> 'text/csv'

15
2018-05-23 13:32



为此,我最终使用'send_data'而不是'send_file'。我不知道是否有必要,但因为我有一个数据流而不是一个文件,我不必乱用磁盘I / O等。 - jaydel
这可能是最好的。修改后的答案供将来参考 - Yule
在大多数情况下,您不需要安装FasterCSV。在ruby 1.9.2中,默认的“CSV”是FasterCSV,在ruby 1.8.7中包含FasterCSV。 - diedthreetimes


答案:


您是否有任何理由将临时文件存储在服务器上?如果是这样的话就足够了(使用 fastercsv,你需要安装):

require 'fastercsv'
FILE_PATH= "root/to/tmpfile.csv"

FasterCSV.open(FILE_PATH, "w") do |csv|
    csv << 'add some data'
end

send_file file_path, :type=>'text/csv'

我建议你可能不需要存储文件,所以只需用以下代码替换FasterCSV.open行:

csv = FasterCSV.generate do |csv|

然后吐出csv作为响应:

send_data csv, :type=> 'text/csv'

15
2018-05-23 13:32



为此,我最终使用'send_data'而不是'send_file'。我不知道是否有必要,但因为我有一个数据流而不是一个文件,我不必乱用磁盘I / O等。 - jaydel
这可能是最好的。修改后的答案供将来参考 - Yule
在大多数情况下,您不需要安装FasterCSV。在ruby 1.9.2中,默认的“CSV”是FasterCSV,在ruby 1.8.7中包含FasterCSV。 - diedthreetimes