easy_sheet_io 0.2.1 → 0.2.4

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
2
  SHA256:
3
- metadata.gz: 3fe769a46f695624ce4e05905ed33313b749c5a77546ac545f723ff63950f430
4
- data.tar.gz: abc63c91428ae99b41c80ed9846ae82970a1f43bc314a3b3d381f32cbf850a58
3
+ metadata.gz: 88df6087923b6ed328df091fa6f6fdf2b833e5a7d96af9a386db127b13b2e3cd
4
+ data.tar.gz: c841d5ed1f39467ee30a3904cb546951c23178343b3f019aa2c8fd9a8872d7a0
5
5
  SHA512:
6
- metadata.gz: 8d75d2aa249909cd5310d2cd7ba360daced800dbcba7a57d3e53050d60a2318720289532c7cfe74f5ccf29fbe8b137debce92ec20d565105c436395b909fb0a3
7
- data.tar.gz: 3ebddcd9ad90b22a43ab6a039029b79b91a897f6f8b4c3a6bbc547f5c878af6dc0e7e5287c379f055d3e0b0accbbffd460bb164b779b7a750f91148c1603c7cf
6
+ metadata.gz: 2eb46d668a0e4465e1f93c6617fd0a2212f41b9b0e90b4d0e566d0f25129779914860f970cdf8491ca7fdbcdc5df598d0c5a496097ae3ee1cf62afed95daef2c
7
+ data.tar.gz: e0ec1d00e0852e70cc4be1ef90d981353803fa796fc9e763631687a4980421b650db1ac6e3c119460e7eabec4313374eee788b0b15768b8c12857f95f5d3a1e2
data/Gemfile CHANGED
@@ -6,9 +6,7 @@ source "https://rubygems.org"
6
6
  gemspec
7
7
 
8
8
  gem "rake", "~> 13.0"
9
-
10
9
  gem "rspec", "~> 3.0"
11
-
12
10
  gem "rubocop", "~> 0.80"
13
11
 
14
12
  gem "daru"
@@ -16,3 +14,4 @@ gem "rover-df"
16
14
  gem "smarter_csv"
17
15
  gem "roo-xls"
18
16
  gem "spreadsheet"
17
+ gem "ast"
data/Gemfile.lock CHANGED
@@ -1,7 +1,15 @@
1
1
  PATH
2
2
  remote: .
3
3
  specs:
4
- easy_sheet_io (0.2.1)
4
+ easy_sheet_io (0.2.3)
5
+ daru (>= 0.3)
6
+ rake (~> 13.0)
7
+ roo-xls (>= 1.2.0)
8
+ rover-df (>= 0.2.7)
9
+ rspec (~> 3.0)
10
+ rubocop (~> 0.80)
11
+ smarter_csv (>= 1.4.2)
12
+ spreadsheet (>= 1.3.0)
5
13
 
6
14
  GEM
7
15
  remote: https://rubygems.org/
@@ -72,6 +80,7 @@ PLATFORMS
72
80
  x86_64-linux
73
81
 
74
82
  DEPENDENCIES
83
+ ast
75
84
  daru
76
85
  easy_sheet_io!
77
86
  rake (~> 13.0)
@@ -31,7 +31,15 @@ Gem::Specification.new do |spec|
31
31
 
32
32
  # Uncomment to register a new dependency of your gem
33
33
  # spec.add_dependency "example-gem", "~> 1.0"
34
-
34
+ spec.add_dependency "rake", "~> 13.0"
35
+ spec.add_dependency "rspec", "~> 3.0"
36
+ spec.add_dependency "rubocop", "~> 0.80"
37
+
38
+ spec.add_dependency "daru", ">= 0.3"
39
+ spec.add_dependency "rover-df", ">= 0.2.7"
40
+ spec.add_dependency "smarter_csv", ">= 1.4.2"
41
+ spec.add_dependency "roo-xls", ">= 1.2.0"
42
+ spec.add_dependency "spreadsheet", ">= 1.3.0"
35
43
  # For more information and examples about making a new gem, checkout our
36
44
  # guide at: https://bundler.io/guides/creating_gem.html
37
45
  end
@@ -1,5 +1,5 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  module EasySheetIo
4
- VERSION = "0.2.1"
4
+ VERSION = "0.2.4"
5
5
  end
data/lib/easy_sheet_io.rb CHANGED
@@ -12,7 +12,7 @@ module EasySheetIo
12
12
  class Error < StandardError; end
13
13
 
14
14
  module_function
15
-
15
+
16
16
  def read(path, **opt)
17
17
  return /csv$/ === path ? read_csv(path, **opt) : read_excel(path, **opt)
18
18
  end
@@ -31,6 +31,7 @@ module EasySheetIo
31
31
 
32
32
  return csv if format.nil?
33
33
 
34
+ # Convert Hash or DataFrame
34
35
  ans = to_hash(csv, **opt)
35
36
  return format==:hash || format=="hash" ? ans : to_df(ans, format: format)
36
37
  end
@@ -46,9 +47,11 @@ module EasySheetIo
46
47
  end
47
48
 
48
49
  # Convert 2d Array to Hash
49
- # ##header: nil -> Default Headers(:column1, column2,...) are generated.
50
- # line_until=nil means the data are picked up until the end line.
51
- def to_hash(array2d, line_from: 1, line_until: nil, header: 0)
50
+ ## header: nil -> Default Headers(:column1, column2,...) are generated.
51
+ ## Option line_ignored is not implemented yet.
52
+ def to_hash(array2d, line_from: 1, line_until: nil, line_ignored: nil,
53
+ header: 0, symbol_header: false,
54
+ replace_to_nil: [], analyze_type: false)
52
55
 
53
56
  # Define Read Range------------
54
57
  lfrom, luntil = line_from, line_until
@@ -63,17 +66,13 @@ module EasySheetIo
63
66
 
64
67
  # Define Data Array------------
65
68
  output = array2d[lfrom...luntil]
69
+ output = fix_array(output, replace_to_nil, analyze_type)
66
70
  output_transpose = output[0].zip(*output[1..])
67
71
  # -----------------------------
68
72
 
69
73
  # Define Header----------------
70
- if header.nil? || header=="string" || header==:string
71
- hd = [*0...(output.longest_line)].map{"column#{_1}"}
72
- elsif header=="symbol" || header==:symbol
73
- hd = [*0...(output.longest_line)].map{"column#{_1}".intern}
74
- else
75
- hd = array2d[header]
76
- end
74
+ hd = header.nil? ? [*0...(output.longest_line)].map{"column#{_1}"} : check_header(array2d[header])
75
+ hd = hd.map { _1.intern } if symbol_header
77
76
  # -----------------------------
78
77
 
79
78
  # Make Hash(Header => Data Array)
@@ -88,8 +87,12 @@ module EasySheetIo
88
87
  return Rover::DataFrame.new(data)
89
88
  end
90
89
  end
91
-
92
- # ##Genarate Hash from excel file
90
+
91
+ #----------------------------
92
+ # Private metods from here
93
+ #----------------------------
94
+
95
+ # Genarate Array from excel file
93
96
  def open_excel(path, sheet_i, encoding: "utf-8")
94
97
  if /xlsx$/ === path
95
98
  puts "Sorry, encoding option is not supported yet for xlsx file." if encoding != "utf-8"
@@ -120,6 +123,49 @@ module EasySheetIo
120
123
 
121
124
  return a2d
122
125
  end
126
+ end
127
+
128
+ # Fix Array (Replace specific values to nil, recognize value type and cast values to the type.)
129
+ def fix_array(array2d, replace_to_nil, analyze_type)
130
+ ans = array2d
131
+
132
+ if replace_to_nil.length > 0
133
+ ans = ans.map { _1.map {|cell| replace_to_nil.include?(cell) ? nil : cell } }
134
+ end
123
135
 
136
+ # if analyze_type
137
+ # ans = ans.map do |column|
138
+
139
+ # end
140
+ # end
141
+
142
+ return ans
143
+ end
144
+
145
+ # Fix blank or duplicated header
146
+ def check_header(header_array)
147
+ # Check Blank
148
+ ans = header_array.map.with_index do |item, i|
149
+ if item.nil?
150
+ "column#{i}"
151
+ elsif item.kind_of?(String)
152
+ /^\s*$/ === item ? "column#{i}" : item.gsub(/\s+/, "")
153
+ else
154
+ item
155
+ end
156
+ end
157
+
158
+ # Check Duplicated Value
159
+ dup_check = (0...(header_array.length)).group_by {|i| ans[i]}
160
+ dup_check.each do |item, i_s|
161
+ if i_s.length > 1
162
+ i_s.each_with_index {|i, index_in_i_s| ans[i] = "#{ans[i]}_#{index_in_i_s}"}
163
+ end
164
+ end
165
+
166
+ return ans
124
167
  end
168
+
169
+ private_class_method :open_excel, :fix_array, :check_header
170
+
125
171
  end
metadata CHANGED
@@ -1,15 +1,127 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: easy_sheet_io
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.2.1
4
+ version: 0.2.4
5
5
  platform: ruby
6
6
  authors:
7
7
  - show-o-atakun
8
8
  autorequire:
9
9
  bindir: exe
10
10
  cert_chain: []
11
- date: 2022-03-23 00:00:00.000000000 Z
12
- dependencies: []
11
+ date: 2022-03-25 00:00:00.000000000 Z
12
+ dependencies:
13
+ - !ruby/object:Gem::Dependency
14
+ name: rake
15
+ requirement: !ruby/object:Gem::Requirement
16
+ requirements:
17
+ - - "~>"
18
+ - !ruby/object:Gem::Version
19
+ version: '13.0'
20
+ type: :runtime
21
+ prerelease: false
22
+ version_requirements: !ruby/object:Gem::Requirement
23
+ requirements:
24
+ - - "~>"
25
+ - !ruby/object:Gem::Version
26
+ version: '13.0'
27
+ - !ruby/object:Gem::Dependency
28
+ name: rspec
29
+ requirement: !ruby/object:Gem::Requirement
30
+ requirements:
31
+ - - "~>"
32
+ - !ruby/object:Gem::Version
33
+ version: '3.0'
34
+ type: :runtime
35
+ prerelease: false
36
+ version_requirements: !ruby/object:Gem::Requirement
37
+ requirements:
38
+ - - "~>"
39
+ - !ruby/object:Gem::Version
40
+ version: '3.0'
41
+ - !ruby/object:Gem::Dependency
42
+ name: rubocop
43
+ requirement: !ruby/object:Gem::Requirement
44
+ requirements:
45
+ - - "~>"
46
+ - !ruby/object:Gem::Version
47
+ version: '0.80'
48
+ type: :runtime
49
+ prerelease: false
50
+ version_requirements: !ruby/object:Gem::Requirement
51
+ requirements:
52
+ - - "~>"
53
+ - !ruby/object:Gem::Version
54
+ version: '0.80'
55
+ - !ruby/object:Gem::Dependency
56
+ name: daru
57
+ requirement: !ruby/object:Gem::Requirement
58
+ requirements:
59
+ - - ">="
60
+ - !ruby/object:Gem::Version
61
+ version: '0.3'
62
+ type: :runtime
63
+ prerelease: false
64
+ version_requirements: !ruby/object:Gem::Requirement
65
+ requirements:
66
+ - - ">="
67
+ - !ruby/object:Gem::Version
68
+ version: '0.3'
69
+ - !ruby/object:Gem::Dependency
70
+ name: rover-df
71
+ requirement: !ruby/object:Gem::Requirement
72
+ requirements:
73
+ - - ">="
74
+ - !ruby/object:Gem::Version
75
+ version: 0.2.7
76
+ type: :runtime
77
+ prerelease: false
78
+ version_requirements: !ruby/object:Gem::Requirement
79
+ requirements:
80
+ - - ">="
81
+ - !ruby/object:Gem::Version
82
+ version: 0.2.7
83
+ - !ruby/object:Gem::Dependency
84
+ name: smarter_csv
85
+ requirement: !ruby/object:Gem::Requirement
86
+ requirements:
87
+ - - ">="
88
+ - !ruby/object:Gem::Version
89
+ version: 1.4.2
90
+ type: :runtime
91
+ prerelease: false
92
+ version_requirements: !ruby/object:Gem::Requirement
93
+ requirements:
94
+ - - ">="
95
+ - !ruby/object:Gem::Version
96
+ version: 1.4.2
97
+ - !ruby/object:Gem::Dependency
98
+ name: roo-xls
99
+ requirement: !ruby/object:Gem::Requirement
100
+ requirements:
101
+ - - ">="
102
+ - !ruby/object:Gem::Version
103
+ version: 1.2.0
104
+ type: :runtime
105
+ prerelease: false
106
+ version_requirements: !ruby/object:Gem::Requirement
107
+ requirements:
108
+ - - ">="
109
+ - !ruby/object:Gem::Version
110
+ version: 1.2.0
111
+ - !ruby/object:Gem::Dependency
112
+ name: spreadsheet
113
+ requirement: !ruby/object:Gem::Requirement
114
+ requirements:
115
+ - - ">="
116
+ - !ruby/object:Gem::Version
117
+ version: 1.3.0
118
+ type: :runtime
119
+ prerelease: false
120
+ version_requirements: !ruby/object:Gem::Requirement
121
+ requirements:
122
+ - - ">="
123
+ - !ruby/object:Gem::Version
124
+ version: 1.3.0
13
125
  description: A simple way to Open .csv, .xls, .xlsx files. You can convert it to 2D
14
126
  array, hash, data frame.
15
127
  email: