gpt4 book ai didi

ruby-on-rails - 从 AWS S3 读取 CSV 文件时获取 "Errno::ENOENT: No such file or directory @ rb_sysopen"

转载 作者:数据小太阳 更新时间:2023-10-29 08:03:22 27 4
gpt4 key购买 nike

我有部署到 Heroku 的应用程序。我添加了通过 CSV 上传用户的功能。为此,我提供了 CSV 上传功能(使用回形针 gem)。

这是我读取文件和创建新用户的代码

def import(file)
CSV.foreach(file.path, headers: true) do |row|
row_hash = row.to_hash.values
data = row_hash[0].split("\t")
.
.
.
end

在本地它工作正常。但是在 heroku 上它给了我以下错误

Errno::ENOENT: No such file or directory @ rb_sysopen - https://s3.amazonaws.com/..../..../sample_csv(2).csv

我引用了以下链接 Errno::ENOENT (No such file or directory) in amazon-s3

File reading from Amazon server, ruby on rails, no match route

但没有任何成功。为了进行更多调试,我从我的本地 Rails 控制台尝试了相同的 url,它给了我同样的错误。

2.2.2 :008 > cp = "https://s3.amazonaws.com/..../..../sample_csv(2).csv"
2.2.2 :008 > f = File.open(cp, "r")
Errno::ENOENT: No such file or directory @ rb_sysopen - https://s3.amazonaws.com

还尝试打开 uri http://ruby-doc.org/stdlib-2.1.0/libdoc/open-uri/rdoc/OpenURI.html .

我可以从浏览器下载相同的文件。

谁能告诉我如何解决这个错误。是否存在任何存储桶权限问题(我已经提供了存储桶的开放访问权限)。

最佳答案

试试这个

require 'open-uri'
require 'csv'

def import(file)
CSV.new(open(file), :headers => :true).each do |row| #First open the file using open
row_hash = row.to_hash.values
data = row_hash[0].split("\t")
.
.
.
end

更多信息可以引用this link

关于ruby-on-rails - 从 AWS S3 读取 CSV 文件时获取 "Errno::ENOENT: No such file or directory @ rb_sysopen",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33146685/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com