我尝试从网址导入CSV文件,但我正在获取Errno::ENAMETOOLONG: file name too long
。我处理文件如下:
require 'open-uri'
url = "http://de65.grepolis.com/data/csv.txt"
url_data = open(url).read()
SmarterCSV.process(url_data, {
...
})
我缺少什么?
答案 0 :(得分:6)
你必须传递一个应该在服务器上的文件名。你现在传递所有数据。做这样的事情
require 'open-uri'
url = "http://de65.grepolis.com/data/csv.txt"
url_data = open(url).read()
File.open('/tmp/file_name', 'w') { |file| file.write(url_data) }
SmarterCSV.process('/tmp/file_name',{ })
答案 1 :(得分:4)
使用标准CSV库通过http网址提取CSV文件时遇到了同样的问题。我能够解决问题,而无需使用以下代码写入临时服务器文件:
require 'open-uri'
require 'csv'
url = "http://de65.grepolis.com/data/csv.txt"
url_data = open(url).read()
CSV.parse(url_data, headers: true).each do |row|
# per row processing code ...
end
答案 2 :(得分:0)