ruby-on-rails - CSV 导入问题

标签 ruby-on-rails ruby csv import

我用它来解析 CSV 文件:

csv_file = CSV.parse(
  file.read(),
  headers:              true,
  header_converters:    :symbol
)

它可以工作,但我想指定编码类型,因此我将: {encoding: 'UTF-8'} 添加到读取方法中,如下所示:

csv_file = CSV.parse(
  file.read({encoding: 'UTF-8'}),
  headers:              true,
  header_converters:    :symbol
)

但我收到此错误:无法将哈希转换为整数

我只是看不出出了什么问题。我已经检查了文档,但它说你可以像这样传递编码,但它确实需要文件作为第一个参数,所以它可能会停在那里,但肯定因为它已经知道正在读取什么文件,所以应该没问题。

我该如何解决这个问题?

更新:

我已更新为以下内容:

def import
  if params[:import_coasters]
    file = params[:import_coasters][:file]
    Park.import_from_csv(file)


def self.import_from_csv(file)
  Park.destroy_all

  csv_file = CSV.parse(
    File.read(file, {encoding: 'UTF-8'}),
    headers:              true,
    header_converters:    :symbol
  )

但我收到以下错误:

无法将 ActionDispatch::Http::UploadedFile 转换为字符串

最佳答案

你已经很接近了。试试这个:

# Step 1: convert the uploaded file object to a file name
uploaded_file = params[:import_coasters][:file]
file_name = uploaded_file.path

# Step 2: To get the input text and see if it's what you expect
text = File.read(
  file_name, 
  {encoding: 'UTF-8'}
)

# Parse the text
csv_file = CSV.parse(
  text,
  headers: true,
  header_converters: :symbol
)

摘自 IO.read 上的 Ruby 1.9.3 文档:

“如果最后一个参数是散列,则它指定内部 open() 的选项。键如下。open_args:对其他参数是独占的。”

http://www.ruby-doc.org/core-1.9.3/IO.html#method-c-read

此外,请查看 UploadedFile 的文档,因为它实际上不是典型的 Ruby File 对象:

http://api.rubyonrails.org/classes/ActionDispatch/Http/UploadedFile.html

关于ruby-on-rails - CSV 导入问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13547018/

相关文章:

ruby-on-rails - 嵌套 has_many

ruby-on-rails - Net::IMAP 失败:连接已关闭

ruby-on-rails - Ruby 中的线程会提高并发性吗?

在 CSV 中跨列写入的 Python 循环

html - 文本空格和制表符分隔表以分号分隔

ruby-on-rails - rspec-mocks 的 double 被设计为只持续一个例子

ruby-on-rails - RVMSUDO 不使用环境变量

ruby-on-rails - Rails错误验证显示在字段下方

ruby - 将 Ruby 库和 gem 与 Shoes 应用程序一起使用

java - 将对象编码为 CSV