From 71e92b76ee449379e347682accecd85caa10dfd0 Mon Sep 17 00:00:00 2001 From: Abdechakour Mrabet Date: Mon, 2 Dec 2024 10:13:23 +0100 Subject: [PATCH] Fix CsvSource quotes parser --- datasources/sources/csv.rb | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/datasources/sources/csv.rb b/datasources/sources/csv.rb index 0821e27..c297f3a 100644 --- a/datasources/sources/csv.rb +++ b/datasources/sources/csv.rb @@ -16,6 +16,7 @@ class Settings < Source::SourceSettings const :url, String const :uncompress, T.nilable(String) const :col_sep, String, default: ',' + const :quote_char, String, default: '"' const :id, T::Array[String] const :lon, String const :lat, String @@ -25,7 +26,7 @@ class Settings < Source::SourceSettings extend T::Generic SettingsType = type_member{ { upper: Settings } } # Generic param - def fetch(url, col_sep) + def fetch(url, col_sep, quote_char) resp = HTTP.follow.get(url) if !resp.status.success? raise [url, resp].inspect @@ -36,11 +37,11 @@ def fetch(url, col_sep) reader = Bzip2::FFI::Reader.read(StringIO.new(reader)) end - CSV.parse(reader, headers: true, col_sep: col_sep, quote_char: nil).each(&:to_h) + CSV.parse(reader, headers: true, col_sep: col_sep, quote_char: quote_char).each(&:to_h) end def each - super(ENV['NO_DATA'] ? [] : fetch(@settings.url, @settings.col_sep)) + super(ENV['NO_DATA'] ? [] : fetch(@settings.url, @settings.col_sep, @settings.quote_char)) end def map_id(feat)