pandas 0.2.0 → 0.3.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 +5 -5
- data/.github/workflows/ci.yml +69 -0
- data/CHANGES.md +36 -0
- data/README.md +1 -1
- data/lib/pandas.rb +39 -11
- data/lib/pandas/data_frame.rb +2 -4
- data/lib/pandas/index.rb +29 -0
- data/lib/pandas/io.rb +6 -0
- data/lib/pandas/loc_indexer.rb +25 -0
- data/lib/pandas/series.rb +44 -0
- data/lib/pandas/version.rb +1 -1
- data/pandas.gemspec +4 -3
- data/requirements.txt +2 -0
- metadata +34 -17
- data/.travis.yml +0 -34
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
|
-
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
2
|
+
SHA256:
|
3
|
+
metadata.gz: c913e79f27264bf7fc6372dab00e706736e14fd9bfdc5b7a9115aa229a26ccc7
|
4
|
+
data.tar.gz: b71d64bc03c8a2f2402ee0d33aca7a8646229806799472a9bb2ad955e4875696
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
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
|
-
[](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 "
|
2
|
+
require "numpy"
|
3
3
|
|
4
|
-
Pandas = PyCall.import_module(
|
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
|
-
|
22
|
-
|
21
|
+
if self.__version__ < "1.0"
|
22
|
+
IXIndexer = self.core.indexing._IXIndexer
|
23
|
+
IXIndexer.__send__ :register_python_type_mapping
|
24
|
+
end
|
23
25
|
|
24
|
-
|
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.
|
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
|
-
|
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
|
data/lib/pandas/data_frame.rb
CHANGED
data/lib/pandas/index.rb
ADDED
@@ -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
|
data/lib/pandas/version.rb
CHANGED
@@ -1 +1 @@
|
|
1
|
-
PANDAS_VERSION = "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", "
|
27
|
-
spec.add_development_dependency "rake"
|
28
|
-
spec.add_development_dependency "rspec"
|
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
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.
|
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:
|
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:
|
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:
|
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: '
|
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: '
|
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: '
|
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: '
|
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
|
-
|
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
|