pandas 0.2.0 → 0.3.4

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
- SHA1:
3
- metadata.gz: 01ae8d45320fa67aa7d7ae6b131c777ec2cd88fb
4
- data.tar.gz: 1cc5bffdfe6f376cc2bbd19c67354c70bec0dd8d
2
+ SHA256:
3
+ metadata.gz: c913e79f27264bf7fc6372dab00e706736e14fd9bfdc5b7a9115aa229a26ccc7
4
+ data.tar.gz: b71d64bc03c8a2f2402ee0d33aca7a8646229806799472a9bb2ad955e4875696
5
5
  SHA512:
6
- metadata.gz: 9b2457bd1efb1b291ff11570dd69f3ee9b95b52e4a631993833c962fd83a216e9b08afd52a2a1a41028c541a895ae3678296cd60244d263d91d601a0a8b0966a
7
- data.tar.gz: 403ec721bc39c1245b1c82f1255dad2ad8462218b4d48fe30a94fbdba838bff17b124b5e731037c438fdcbdd5806878a166a9cc3dc94c28e4fe4351c5f80ae22
6
+ metadata.gz: 6eed3dc70cb8744495021c874c2ce22a0ffc54b51a93166b0e9bf405919dc9b9f8c0399bae1100d59808e6c299d5951e158151d5364a5dabfaf41f8160a6cad5
7
+ data.tar.gz: 9164bbe1b1419aadfd1e8695129aaebaf70dcbf297baf0e54a68ec0d93a458d48a59187dfac58853410558f88f85e1686f752d650bd980c5dd887ecb81f3ee9e
@@ -0,0 +1,69 @@
1
+ name: CI
2
+
3
+ on:
4
+ push:
5
+ branches:
6
+ - master
7
+ pull_request:
8
+ types:
9
+ - opened
10
+ - synchronize
11
+ - reopened
12
+
13
+ jobs:
14
+ test:
15
+ name: ${{ matrix.os}} ${{ matrix.ruby }} ${{ matrix.python }}-${{ matrix.python_arch }}
16
+ runs-on: ${{ matrix.os }}
17
+
18
+ strategy:
19
+ fail-fast: false
20
+ matrix:
21
+ os:
22
+ - ubuntu-latest
23
+ - macos-latest
24
+ ruby:
25
+ - 3.0
26
+ - 2.7
27
+ - 2.6
28
+ - 2.5
29
+ - 2.4
30
+ - debug
31
+ python:
32
+ - 3.8.x
33
+ - 3.7.x
34
+ - 3.6.x
35
+ - 2.7.x
36
+ python_arch:
37
+ - x64
38
+
39
+ steps:
40
+ - uses: actions/checkout@v2
41
+ with:
42
+ fetch-depth: 1
43
+
44
+ - uses: ruby/setup-ruby@v1
45
+ with:
46
+ ruby-version: ${{ matrix.ruby }}
47
+
48
+ - uses: actions/setup-python@v1
49
+ with:
50
+ python-version: ${{ matrix.python }}
51
+ architecture: ${{ matrix.python_arch }}
52
+
53
+ - run: sudo apt-get install libsqlite3-dev
54
+ if: matrix.os == 'ubuntu-latest'
55
+
56
+ - run: brew install sqlite3
57
+ if: matrix.os == 'macos-latest'
58
+
59
+ - run: pip install -r requirements.txt
60
+
61
+ - run: gem install bundler
62
+ - run: bundle install
63
+
64
+ - run: bundle exec rake
65
+ env:
66
+ PYTHON: python
67
+
68
+ - run: rake build
69
+ - run: gem install pkg/*.gem
data/CHANGES.md CHANGED
@@ -1,5 +1,41 @@
1
1
  # The chenge history of Pandas wrapper for Ruby
2
2
 
3
+ ## 0.3.4
4
+
5
+ * Add `to_a` methods in `Pandas::Series` and `Pandas::Index`
6
+
7
+ * Add `length` method in `Pandas::Series` and `Pandas::Index`
8
+
9
+ ## 0.3.3
10
+
11
+ * Support array index in `Pandas::Series#[]`
12
+
13
+ * Add predicate methods for `Pandas::Index` and `Pandas::Series`
14
+
15
+ * Support closed-end string ranges in `Pandas::Series#[]`
16
+
17
+ * Support string array index in `Pandas::DataFrame#loc[]`
18
+
19
+ * Support array index in `Pandas::DataFrame#iloc[]`
20
+
21
+ ## 0.3.2
22
+
23
+ * Fix for pandas 1.0
24
+
25
+ ## 0.3.1
26
+
27
+ * Fix `Pandas.read_sql_table` for passing optional parameters such as `index_col`
28
+
29
+ ## 0.3.0
30
+
31
+ * Fix the module path of `DatetimeIndex` to support pandas < 0.20
32
+
33
+ Fixes #5
34
+
35
+ *Daniel Baark*
36
+
37
+ * Support to pass an AR model class to `read_sql_table` instead of both `table_name` and `conn`
38
+
3
39
  ## 0.2.0
4
40
 
5
41
  * Support a connection of ActiveRecord in `read_sql_table` and `read_sql_query`
data/README.md CHANGED
@@ -1,6 +1,6 @@
1
1
  # Pandas wrapper for Ruby
2
2
 
3
- [![Build Status](https://travis-ci.org/mrkn/pandas.rb.svg)](https://travis-ci.org/mrkn/pandas.rb)
3
+ [![CI](https://github.com/mrkn/pandas.rb/workflows/CI/badge.svg?branch=master&event=push)](https://github.com/mrkn/pandas.rb/actions?query=workflow%3ACI)
4
4
 
5
5
  This library enables to directry call [pandas](http://pandas.pydata.org/) from Ruby language.
6
6
  This uses [pycall](https://github.com/mrkn/pycall).
data/lib/pandas.rb CHANGED
@@ -1,7 +1,7 @@
1
1
  require "pandas/version"
2
- require "pycall"
2
+ require "numpy"
3
3
 
4
- Pandas = PyCall.import_module('pandas')
4
+ Pandas = PyCall.import_module("pandas")
5
5
  module Pandas
6
6
  VERSION = PANDAS_VERSION
7
7
  Object.send :remove_const, :PANDAS_VERSION
@@ -18,16 +18,30 @@ module Pandas
18
18
  LocIndexer = self.core.indexing._LocIndexer
19
19
  LocIndexer.__send__ :register_python_type_mapping
20
20
 
21
- IXIndexer = self.core.indexing._IXIndexer
22
- IXIndexer.__send__ :register_python_type_mapping
21
+ if self.__version__ < "1.0"
22
+ IXIndexer = self.core.indexing._IXIndexer
23
+ IXIndexer.__send__ :register_python_type_mapping
24
+ end
23
25
 
24
- MultiIndex = self.core.indexing.MultiIndex
26
+ if self.__version__ >= "1.0"
27
+ MultiIndex = self.core.indexes.multi.MultiIndex
28
+ else
29
+ MultiIndex = self.core.indexing.MultiIndex
30
+ end
25
31
  MultiIndex.__send__ :register_python_type_mapping
26
32
 
27
- DatetimeIndex = self.core.indexes.datetimes.DatetimeIndex
33
+ DatetimeIndex = if self.__version__ >= "0.20"
34
+ self.core.indexes.datetimes.DatetimeIndex
35
+ else
36
+ self.tseries.index.DatetimeIndex
37
+ end
28
38
  DatetimeIndex.__send__ :register_python_type_mapping
29
39
 
30
- Index = self.core.index.Index
40
+ if self.__version__ >= "1.0"
41
+ Index = self.core.indexes.base.Index
42
+ else
43
+ Index = self.core.index.Index
44
+ end
31
45
  Index.__send__ :register_python_type_mapping
32
46
 
33
47
  DataFrameGroupBy = self.core.groupby.DataFrameGroupBy
@@ -38,23 +52,37 @@ module Pandas
38
52
 
39
53
  IO = self.io
40
54
 
41
- def self.read_sql_table(table_name, conn, *args)
55
+ def self.read_sql_table(table_name, conn=nil, *args, **kwargs)
56
+ if conn.nil? && IO.is_activerecord_model?(table_name)
57
+ unless table_name.table_name
58
+ raise ArgumentError, "The given model does not have its table_name"
59
+ end
60
+ table_name, conn = table_name.table_name, table_name.connection
61
+ end
62
+
63
+ unless conn
64
+ raise ArgumentError, "wrong number of arguments (given 1, expected 2+)"
65
+ end
66
+
42
67
  if IO.is_activerecord_datasource?(conn)
43
68
  require 'pandas/io/active_record'
44
- return IO::Helpers.read_sql_table_from_active_record(table_name, conn, *args)
69
+ return IO::Helpers.read_sql_table_from_active_record(table_name, conn, *args, **kwargs)
45
70
  end
46
71
  super
47
72
  end
48
73
 
49
- def self.read_sql_query(query, conn, *args)
74
+ def self.read_sql_query(query, conn, *args, **kwargs)
50
75
  if IO.is_activerecord_datasource?(conn)
51
76
  require 'pandas/io/active_record'
52
- return IO::Helpers.read_sql_query_from_active_record(query, conn, *args)
77
+ return IO::Helpers.read_sql_query_from_active_record(query, conn, *args, **kwargs)
53
78
  end
54
79
  super
55
80
  end
56
81
 
57
82
  require 'pandas/data_frame'
83
+ require 'pandas/index'
58
84
  require 'pandas/io'
85
+ require 'pandas/loc_indexer'
59
86
  require 'pandas/options'
87
+ require 'pandas/series'
60
88
  end
@@ -2,10 +2,8 @@ require 'pandas'
2
2
 
3
3
  module Pandas
4
4
  class DataFrame
5
- def [](*key)
6
- if key.length == 1 && key[0].is_a?(Array)
7
- key[0] = PyCall::List.new(key[0])
8
- end
5
+ def [](key)
6
+ key = PyCall::List.new(key) if key.is_a?(Array)
9
7
  super
10
8
  end
11
9
  end
@@ -0,0 +1,29 @@
1
+ require 'pandas'
2
+
3
+ module Pandas
4
+ class Index
5
+ def monotonic?
6
+ is_monotonic
7
+ end
8
+
9
+ def monotonic_decreasing?
10
+ is_monotonic_decreasing
11
+ end
12
+
13
+ def monotonic_increasing?
14
+ is_monotonic_increasing
15
+ end
16
+
17
+ def unique?
18
+ is_unique
19
+ end
20
+
21
+ def length
22
+ size
23
+ end
24
+
25
+ def to_a
26
+ Array.new(length) {|i| self[i] }
27
+ end
28
+ end
29
+ end
data/lib/pandas/io.rb CHANGED
@@ -2,6 +2,12 @@ require 'pandas'
2
2
 
3
3
  module Pandas
4
4
  module IO
5
+ def self.is_activerecord_model?(obj)
6
+ return false unless defined?(::ActiveRecord)
7
+ return true if obj.is_a?(Class) && obj < ActiveRecord::Base
8
+ false
9
+ end
10
+
5
11
  def self.is_activerecord_datasource?(obj)
6
12
  return false unless defined?(::ActiveRecord)
7
13
  return true if obj.is_a?(::ActiveRecord::ConnectionAdapters::AbstractAdapter)
@@ -0,0 +1,25 @@
1
+ require 'pandas'
2
+
3
+ module Pandas
4
+ class LocIndexer
5
+ def [](*keys)
6
+ for i in 0...keys.length
7
+ if keys[i].is_a? Array
8
+ keys[i] = PyCall::List.new(keys[i])
9
+ end
10
+ end
11
+ super
12
+ end
13
+ end
14
+
15
+ class IlocIndexer
16
+ def [](*keys)
17
+ for i in 0...keys.length
18
+ if keys[i].is_a? Array
19
+ keys[i] = PyCall::List.new(keys[i])
20
+ end
21
+ end
22
+ super
23
+ end
24
+ end
25
+ end
@@ -0,0 +1,44 @@
1
+ require 'pandas'
2
+
3
+ module Pandas
4
+ class Series
5
+ def [](*key)
6
+ if key.length == 1
7
+ case key[0]
8
+ when Array
9
+ key[0] = PyCall::List.new(key[0])
10
+ when Range
11
+ case key[0].begin
12
+ when String
13
+ key[0] = key[0].begin ... key[0].end # force exclude-end
14
+ end
15
+ end
16
+ end
17
+ super
18
+ end
19
+
20
+ def monotonic?
21
+ is_monotonic
22
+ end
23
+
24
+ def monotonic_decreasing?
25
+ is_monotonic_decreasing
26
+ end
27
+
28
+ def monotonic_increasing?
29
+ is_monotonic_increasing
30
+ end
31
+
32
+ def unique?
33
+ is_unique
34
+ end
35
+
36
+ def length
37
+ size
38
+ end
39
+
40
+ def to_a
41
+ Array.new(length) {|i| self[i] }
42
+ end
43
+ end
44
+ end
@@ -1 +1 @@
1
- PANDAS_VERSION = "0.2.0"
1
+ PANDAS_VERSION = "0.3.4"
data/pandas.gemspec CHANGED
@@ -22,10 +22,11 @@ Gem::Specification.new do |spec|
22
22
  spec.require_paths = ["lib"]
23
23
 
24
24
  spec.add_dependency "pycall", ">= 1.0.0"
25
+ spec.add_dependency "numpy"
25
26
 
26
- spec.add_development_dependency "bundler", "~> 1.15"
27
- spec.add_development_dependency "rake", "~> 10.0"
28
- spec.add_development_dependency "rspec", "~> 3.0"
27
+ spec.add_development_dependency "bundler", ">= 1.17.2"
28
+ spec.add_development_dependency "rake"
29
+ spec.add_development_dependency "rspec"
29
30
  spec.add_development_dependency "activerecord", ">= 4.2"
30
31
  spec.add_development_dependency "sqlite3"
31
32
  end
data/requirements.txt ADDED
@@ -0,0 +1,2 @@
1
+ pandas
2
+ sqlalchemy
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: pandas
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.2.0
4
+ version: 0.3.4
5
5
  platform: ruby
6
6
  authors:
7
7
  - Kenta Murata
8
8
  autorequire:
9
9
  bindir: exe
10
10
  cert_chain: []
11
- date: 2017-09-11 00:00:00.000000000 Z
11
+ date: 2021-04-25 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: pycall
@@ -24,48 +24,62 @@ dependencies:
24
24
  - - ">="
25
25
  - !ruby/object:Gem::Version
26
26
  version: 1.0.0
27
+ - !ruby/object:Gem::Dependency
28
+ name: numpy
29
+ requirement: !ruby/object:Gem::Requirement
30
+ requirements:
31
+ - - ">="
32
+ - !ruby/object:Gem::Version
33
+ version: '0'
34
+ type: :runtime
35
+ prerelease: false
36
+ version_requirements: !ruby/object:Gem::Requirement
37
+ requirements:
38
+ - - ">="
39
+ - !ruby/object:Gem::Version
40
+ version: '0'
27
41
  - !ruby/object:Gem::Dependency
28
42
  name: bundler
29
43
  requirement: !ruby/object:Gem::Requirement
30
44
  requirements:
31
- - - "~>"
45
+ - - ">="
32
46
  - !ruby/object:Gem::Version
33
- version: '1.15'
47
+ version: 1.17.2
34
48
  type: :development
35
49
  prerelease: false
36
50
  version_requirements: !ruby/object:Gem::Requirement
37
51
  requirements:
38
- - - "~>"
52
+ - - ">="
39
53
  - !ruby/object:Gem::Version
40
- version: '1.15'
54
+ version: 1.17.2
41
55
  - !ruby/object:Gem::Dependency
42
56
  name: rake
43
57
  requirement: !ruby/object:Gem::Requirement
44
58
  requirements:
45
- - - "~>"
59
+ - - ">="
46
60
  - !ruby/object:Gem::Version
47
- version: '10.0'
61
+ version: '0'
48
62
  type: :development
49
63
  prerelease: false
50
64
  version_requirements: !ruby/object:Gem::Requirement
51
65
  requirements:
52
- - - "~>"
66
+ - - ">="
53
67
  - !ruby/object:Gem::Version
54
- version: '10.0'
68
+ version: '0'
55
69
  - !ruby/object:Gem::Dependency
56
70
  name: rspec
57
71
  requirement: !ruby/object:Gem::Requirement
58
72
  requirements:
59
- - - "~>"
73
+ - - ">="
60
74
  - !ruby/object:Gem::Version
61
- version: '3.0'
75
+ version: '0'
62
76
  type: :development
63
77
  prerelease: false
64
78
  version_requirements: !ruby/object:Gem::Requirement
65
79
  requirements:
66
- - - "~>"
80
+ - - ">="
67
81
  - !ruby/object:Gem::Version
68
- version: '3.0'
82
+ version: '0'
69
83
  - !ruby/object:Gem::Dependency
70
84
  name: activerecord
71
85
  requirement: !ruby/object:Gem::Requirement
@@ -101,9 +115,9 @@ executables: []
101
115
  extensions: []
102
116
  extra_rdoc_files: []
103
117
  files:
118
+ - ".github/workflows/ci.yml"
104
119
  - ".gitignore"
105
120
  - ".rspec"
106
- - ".travis.yml"
107
121
  - CHANGES.md
108
122
  - Gemfile
109
123
  - LICENSE.txt
@@ -114,11 +128,15 @@ files:
114
128
  - data/titanic.csv
115
129
  - lib/pandas.rb
116
130
  - lib/pandas/data_frame.rb
131
+ - lib/pandas/index.rb
117
132
  - lib/pandas/io.rb
118
133
  - lib/pandas/io/active_record.rb
134
+ - lib/pandas/loc_indexer.rb
119
135
  - lib/pandas/options.rb
136
+ - lib/pandas/series.rb
120
137
  - lib/pandas/version.rb
121
138
  - pandas.gemspec
139
+ - requirements.txt
122
140
  homepage: https://github.com/mrkn/pandas.rb
123
141
  licenses:
124
142
  - MIT
@@ -138,8 +156,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
138
156
  - !ruby/object:Gem::Version
139
157
  version: '0'
140
158
  requirements: []
141
- rubyforge_project:
142
- rubygems_version: 2.6.12
159
+ rubygems_version: 3.2.3
143
160
  signing_key:
144
161
  specification_version: 4
145
162
  summary: Pandas wrapper for Ruby
data/.travis.yml DELETED
@@ -1,34 +0,0 @@
1
- sudo: false
2
- language: ruby
3
-
4
- rvm:
5
- - ruby-head
6
- - 2.4.0
7
- - 2.3.1
8
- - 2.2.5
9
- - 2.1.10
10
-
11
- addons:
12
- apt:
13
- packages:
14
- - python3
15
- - python3-dev
16
- - python3-all
17
- - python3-all-dev
18
-
19
- env:
20
- matrix:
21
- - PYTHON=python
22
- - LIBPYTHON=/opt/python/3.5.3/lib/libpython3.5m.so
23
-
24
- before_install:
25
- - gem update --system
26
- - gem update bundler
27
-
28
- before_script:
29
- - pip install pandas
30
- - pip3 install numpy
31
-
32
- matrix:
33
- allow_failures:
34
- - env: PYTHON=python # Ignore failed on python 2.7