Sha256: fd427dd802e689daabd5e7640cc497c13d0f76ad665569af136c4e25815b44e2
Contents?: true
Size: 1.83 KB
Versions: 2
Compression:
Stored size: 1.83 KB
Contents
if RUBY_VERSION >= '1.9' require 'csv' ::FasterCSV = ::CSV else begin require 'fastercsv' rescue ::LoadError $stderr.puts "[remote_table gem] You probably need to manually install the fastercsv gem and/or require it in your Gemfile." raise $! end end class RemoteTable class Format class Delimited < Format include Textual def each(&blk) convert_file_to_utf8! remove_useless_characters! skip_rows! ::FasterCSV.foreach(t.local_file.path, fastercsv_options) do |row| ordered_hash = ::ActiveSupport::OrderedHash.new filled_values = 0 case row when ::FasterCSV::Row row.each do |header, value| next if header.blank? value = '' if value.nil? ordered_hash[header] = value filled_values += 1 if value.present? end when ::Array index = 0 row.each do |value| value = '' if value.nil? ordered_hash[index] = value filled_values += 1 if value.present? index += 1 end end yield ordered_hash if t.properties.keep_blank_rows or filled_values > 0 end ensure delete_file! end private FASTERCSV_OPTIONS = %w{ unconverted_fields col_sep headers row_sep return_headers header_converters quote_char skip_blanks converters force_quotes } def fastercsv_options hsh = t.options.slice *FASTERCSV_OPTIONS hsh.merge! 'skip_blanks' => !t.properties.keep_blank_rows hsh.reverse_merge! 'headers' => :first_row hsh.reverse_merge! 'col_sep' => t.properties.delimiter hsh.symbolize_keys end end end end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
remote_table-1.1.4 | lib/remote_table/format/delimited.rb |
remote_table-1.1.3 | lib/remote_table/format/delimited.rb |