Rails 3,activerecord-import gem,CSV

时间:2011-06-24 13:13:36

标签: ruby-on-rails ruby csv

阅读this question后,我有这个rake任务:

desc "Import sales" 
task :import_sales => :environment do
  sales = File.open(Rails.root.join("public", "system", "xmls", "3", "original", "first.csv"),"r").map do |line|
    isbn, date, quantity, value, channel = line.split("\,")
    Importsale.new(:isbn => isbn, :date => date, :quantity => quantity, :value => value, :channel => channel)
  end
  Importsale.import sales
end

和一些像这样的csv数据:

9780953893201,30/5/10,4,25.6,UK Home
9780953893201,25/6/10,3,19.2,UK Home
9780953893201,30/7/10,6,95.94,UK Home
9780953893201,27/8/10,1,15.99,Export
9780953893201,27/8/10,13,207.87,UK Home
9780953893201,27/8/10,1,6.4,UK Home
9780953893201,24/9/10,14,223.86,UK Home
9780953893201,24/9/10,5,32,UK Home

但是rake任务没有拆分CSV文件 - 我正在导入一条记录,最后一个通道包含。

UK Home
9780953893201

是否使用map停止将csv解析为行?如果我使用each或each_line,我会收到“无效参数”错误。

1 个答案:

答案 0 :(得分:2)

因为没人写答案......

File.readlines(...).map do |line|
    ...
end