У меня было невероятное время, пытаясь импортировать CSV файл в ruby-1.9.2.
Файл, который я пытаюсь проанализировать, имеет:
- запятые в столбцах
- цитаты в столбцах
- использует '@' как: col_sep
csv.txt(представительский ввод, действительный - 101k строк):
㔾@㔾@jié@"seal" radical in Chinese characters, (Kangxi radical 26)
Мой код:
require 'csv'
CSV.foreach("/Users/adam/Desktop/csvtest.txt", {:col_sep => "@"}) do |row|
puts row.to_s
end
Мой желаемый результат:
["㔾", "㔾", "jié", "\"seal\" radical in Chinese characters, (Kangxi radical 26)"]
Что я получаю для вывода:
CSV::MalformedCSVError: Unclosed quoted field on line 1.
from /Users/adam/.rvm/rubies/ruby-1.9.2-p290/lib/ruby/1.9.1/CSV.rb:1910:in `block in shift'
from /Users/adam/.rvm/rubies/ruby-1.9.2-p290/lib/ruby/1.9.1/CSV.rb:1825:in `loop'
from /Users/adam/.rvm/rubies/ruby-1.9.2-p290/lib/ruby/1.9.1/CSV.rb:1825:in `shift'
from /Users/adam/.rvm/rubies/ruby-1.9.2-p290/lib/ruby/1.9.1/CSV.rb:1767:in `each'
from /Users/adam/.rvm/rubies/ruby-1.9.2-p290/lib/ruby/1.9.1/CSV.rb:1202:in `block in foreach'
from /Users/adam/.rvm/rubies/ruby-1.9.2-p290/lib/ruby/1.9.1/CSV.rb:1340:in `open'
from /Users/adam/.rvm/rubies/ruby-1.9.2-p290/lib/ruby/1.9.1/CSV.rb:1201:in `foreach'
from (irb):31
from /Users/adam/.rvm/rubies/ruby-1.9.2-p290/bin/irb:16:in `<main>'
В нем говорится, что есть закрытые цитаты feilds, но я вижу, что кавычки открываются и закрываются.
Выход из кавычек ничего не делает. Я получаю ту же ошибку ([email protected]""seal"" r...
).
Изменение их на одинарные кавычки заставляет его работать ([email protected]'seal' r...
).
Проблема в том, что мне нужно, чтобы они были в двойных кавычках.
Любые идеи?