csv_splitter 0.1.3 → 0.1.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
- SHA1:
3
- metadata.gz: 3d4c6e8379e03d092ce3737b1bf1b6ceb1e28e41
4
- data.tar.gz: 967767696bfb2ce34b59cb822f4f0eccd6b5b4b9
2
+ SHA256:
3
+ metadata.gz: 9ceccb67d126def8fca5d9d5f66da973581c868bdb1f7047806edf0e1d4ff99f
4
+ data.tar.gz: 1fab4f3a29814ce59747fff9352d697476b6ee9382ebaec97af455b64a1a9ffa
5
5
  SHA512:
6
- metadata.gz: 2461bae7613becbe0567c16147c885b6b55c03c65d30bf0d7838f2d03d1442271960f9ffc34e069edff06d6ddf012113bee38f6cf8d8fdd3255b3245b2f97056
7
- data.tar.gz: 59ad308ea968d8cfd7d486b044ad78b251873fb878968d3166b96f376107b5fbd5d0f1a31538530f7029b9791aa6f22fa7f2d6f7c98e3fea99ecd05c49cc721c
6
+ metadata.gz: 35dffac222aad50190fe99ab21d1f5a682a6bb646fd9c413c0540150c0df293424c406a5c723a7f70d3c13baebb9d6740b1b03deab4634068473648dce969e7f
7
+ data.tar.gz: 4987507d38701874d91201fccde856466ad56064a26aa6028993422e0caf24d7dac55b59e6f463885c958a149d535a380f614c2ca9df09ca5446d457de49df3f
@@ -1,11 +1,12 @@
1
1
  require 'csv'
2
2
  require 'zaru'
3
3
  class CsvSplitter
4
- def initialize(csv, out_path: '/tmp', column_to_split_by:, transform_headers: nil)
4
+ def initialize(csv, out_path: '/tmp', column_to_split_by:, transform_headers: nil, suppress_logging: false)
5
5
  @transform_header = transform_headers
6
6
  @file = File.read(csv).encode('UTF-8', :invalid => :replace, :undef => :replace, :replace => '')
7
7
  @out_path = out_path
8
8
  @column_to_split_by = column_to_split_by
9
+ @suppress_logging = suppress_logging
9
10
  end
10
11
 
11
12
  def split!
@@ -15,7 +16,6 @@ class CsvSplitter
15
16
  sorting_index = csv_file.headers.index(normalized_key)
16
17
  csv_file.sort_by{|v| v[sorting_index] }.each do |row|
17
18
  current = Zaru.sanitize!(row[normalized_key].to_s.gsub(/_/, ' ').strip)
18
-
19
19
  new_file = "#{@out_path}/#{current}_new.csv"
20
20
  if last_file != new_file
21
21
  write_mode = 'w'
@@ -27,7 +27,7 @@ class CsvSplitter
27
27
  CSV.open(new_file, write_mode, write_headers: write_mode == 'w', headers: row.headers.map(&transform_block)) do |csv|
28
28
  csv << row.to_h.values
29
29
  end
30
- puts "wrote to file for column #{current}"
30
+ puts "wrote to file for column #{current}" unless @suppress_logging
31
31
  end
32
32
  end
33
33
  end
@@ -1,3 +1,3 @@
1
1
  module CsvSplitter
2
- VERSION = "0.1.3"
2
+ VERSION = "0.1.5"
3
3
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: csv_splitter
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.1.3
4
+ version: 0.1.5
5
5
  platform: ruby
6
6
  authors:
7
7
  - Damien Pyles
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2019-12-02 00:00:00.000000000 Z
11
+ date: 2020-07-07 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: zaru
@@ -110,7 +110,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
110
110
  version: '0'
111
111
  requirements: []
112
112
  rubyforge_project:
113
- rubygems_version: 2.6.14
113
+ rubygems_version: 2.7.6.2
114
114
  signing_key:
115
115
  specification_version: 4
116
116
  summary: Utility to split a CSV into multiple according based on a particular column.