2

尝试打开文件以使用roo gem 导入数据时,我在 AWS s3 存储中存储了一个文件,它引发以下错误Errno::ENOENT: No such file or directory @ rb_sysopen

def self.import(file, user_id)
        imported_file = ImportedFile.find(file)
        spreadsheet = Roo::Spreadsheet.open(open(imported_file.file_url), extension: :csv)
        spreadsheet = Roo::Spreadsheet.open(imported_file.file)
      header = spreadsheet.row(1)//raising error here
end

我什至也试过这个

spreadsheet = Roo::Spreadsheet.open(imported_file.file_url)

在日志中出现以下错误

Errno::ENOENT: No such file or directory @ rb_sysopen - /uploads/imported_files/7a6f0463-b3cd-48f8-a579-bc27951242fe/13c96e3e-d3f3-4ed8-8d9a-b9ea03c0cc8c.csv
4

2 回答 2

5

要打开 URL,您应该open-uri首先需要该库:

require 'open-uri'

请参阅示例:

open('http://example.com/')
# throws Errno::ENOENT: No such file or directory @ rb_sysopen - http://example.com/

require 'open-uri'
open('http://example.com/')
# opens the website
于 2017-10-11T05:42:47.590 回答
2

最后,以下代码对我有用。

spreadsheet = Roo::Spreadsheet.open(open(imported_file.file_url), extension: File.extname(imported_file.file_url).gsub('.','').to_sym) rescue nil
于 2017-10-11T09:31:08.170 回答