生成CSV文件Rails 4.2时设置字符编码

时间:2016-08-08 05:17:19

标签: ruby-on-rails csv character-encoding cjk shift-jis

我有一个模块可以在包含时生成模型的csv文件。

# app/models/concerns/csv_exportable.rb
module CsvExportable
  extend ActiveSupport::Concern

  included do
    def self.to_csv(options = {})
      CSV.generate(options) do |csv|
        csv << column_names
        all.each do |thismodel|
          csv << thismodel.attributes.values_at(*column_names)
        end
      end
    end
  end
end

我将模块包含在我想要生成csv文件的模型中

# app/models/product.rb
class Reason < ActiveRecord::Base
  include CsvExportable
  .
  .
end

在我的控制器中我做了

respond_to do |format|
  format.html
  format.csv { send_data @products.to_csv, filename: 'products.csv' }
end

我想将生成的csv文件的字符编码设置为Shift_JIS,而不是默认的utf-8。做这个的最好方式是什么 ?谢谢你
修改

我试过

format.csv { send_data (@products.to_csv).encode("SHIFT-JIS"), filename: 'products.csv' }

现在我收到错误Encoding::ConverterNotFoundError code converter not found (UTF-8 to SHIFT-JIS)

2 个答案:

答案 0 :(得分:1)

format.csv { 
  send_data (@products.to_csv).encode(Encoding::SJIS), 
  filename: 'products.csv', 
  type: 'text/csv; charset=shift_jis'
}

诀窍

答案 1 :(得分:0)

您可以在encoding: '<non utf-8 encoding>'中传递options散列中的to_csv选项,以便在生成csv时CsvExportable方法可用CSV.generate文件。

相关问题